前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >LeetCode 651. 4键键盘(DP,Ctrl+CV)

LeetCode 651. 4键键盘(DP,Ctrl+CV)

作者头像
Michael阿明
发布2020-07-13 14:54:14
1.6K0
发布2020-07-13 14:54:14
举报
文章被收录于专栏:Michael阿明学习之路

1. 题目

假设你有一个特殊的键盘包含下面的按键:

代码语言:javascript
复制
Key 1: (A):在屏幕上打印一个 'A'。

Key 2: (Ctrl-A):选中整个屏幕。

Key 3: (Ctrl-C):复制选中区域到缓冲区。

Key 4: (Ctrl-V):将缓冲区内容输出到上次输入的结束位置,并显示在屏幕上。

现在,你只可以按键 N 次(使用上述四种按键),请问屏幕上最多可以显示几个 'A’呢?

代码语言:javascript
复制
样例 1:
输入: N = 3
输出: 3
解释: 
我们最多可以在屏幕上显示三个'A'通过如下顺序按键:
A, A, A
 
样例 2:
输入: N = 7
输出: 9
解释: 
我们最多可以在屏幕上显示九个'A'通过如下顺序按键:
A, A, A, Ctrl A, Ctrl C, Ctrl V, Ctrl V
代码语言:javascript
复制
注释:
1 <= N <= 50
结果不会超过 32 位有符号整数范围。

来源:力扣(LeetCode) 链接:https://leetcode-cn.com/problems/4-keys-keyboard 著作权归领扣网络所有。商业转载请联系官方授权,非商业转载请注明出处。

2. 解题

在这里插入图片描述
在这里插入图片描述
  • 只按一个键A,直接在前一个状态的个数+1
  • 按ACV的话,可以从前面所有可能的位置ACV一次以后,一直VVV
  • 可以粘贴以后,VVV好于ACV,但是ACVV 好于VVVV(数量一样,但是前者粘贴板的A数量多)
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
代码语言:javascript
复制
class Solution {
public:
    int maxA(int N) {
    	vector<int> dp(N+1,0);
    	//dp[i] 表示,第 i 次按下键的最多A个数
    	for(int i = 1, j; i <= N; ++i)
    	{
    		dp[i] = max(dp[i], dp[i-1]+1);//按下A键
    		for(j = 0; j <= i-2; ++j)
    		//从前面可以的地方选一次进行ACV,后面一直V...
    		// -2 表示 AC的少了2次,后面可以一直粘(i-j-2)次 + 原来自己一次
    			dp[i] = max(dp[i], dp[j]*(i-j-1));
    	}
    	return dp[N];
    }
};

0 ms 6.1 MB

本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
原始发表:2020/07/06 ,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 1. 题目
  • 2. 解题
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档