最初在一个记事本上只有一个字符 'A'。你每次可以对这个记事本进行两种操作:

  Copy All (复制全部) : 你可以复制这个记事本中的所有字符(部分的复制是不允许的)。
  Paste (粘贴) : 你可以粘贴你上一次复制的字符。

给定一个数字 n 。你需要使用最少的操作次数,在记事本中打印出恰好 n 个 'A'。输出能够打印出 n 个 'A' 的最少操作次数。

示例 1:

输入: 3
输出: 3
解释:
最初, 我们只有一个字符 'A'。
第 1 步, 我们使用 Copy All 操作。
第 2 步, 我们使用 Paste 操作来获得 'AA'。
第 3 步, 我们使用 Paste 操作来获得 'AAA'。

说明:

n 的取值范围是 [1, 1000] 。

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

第一反应是二维DP

dp[i][j] 表示总共i个字母 粘贴板有j个字母 的最小步骤

class Solution {
public:
int minSteps(int n) {
// dp[i][j] 总共i个字母 粘贴板有j个字母 的最小步骤
int dp[n+1][n+1];
memset(dp, -1, sizeof dp);
dp[1][0] = 0;
int ans = -1;
for (int i = 1; i <= n; i++) {
for (int j = 0; j <= i; j++) {
if (dp[i][j] != -1) {
if (dp[i][i] == -1 || dp[i][i] > dp[i][j] + 1) {
dp[i][i] = dp[i][j] + 1;
}
if (i + j <= n && (dp[i + j][j] == -1 || dp[i + j][j] > dp[i][j] + 1)) {
dp[i + j][j] = dp[i][j] + 1;
}
}
if (i == n && dp[i][j] != -1 && (ans == -1 || ans > dp[i][j])) {
ans = dp[i][j];
}
}
}
return ans;
}
};

不过运行速度有点慢……

对于任何一个数 n,都可以先凑到该数的一个因数 x ,然后 copy all 复制 n/x-1 次,枚举因数即可

如果 n 为质数,就只能使用 1 来复制 n-1 次

class Solution {
public:
int minSteps(int n) {
int dp[n+1] = {0};
for (int i = 2; i <= n; i++) {
dp[i] = i;
for (int j = 1; j < i; j++) {
if (i % j == 0) {
dp[i] = min(dp[i], dp[j] + i / j);
}
}
}
return dp[n];
}
};

复杂度和上面一样,O(n^2) 不过可以优化一下

考虑到一个数x=p*q, p和q是两个质数,那么总共打印的次数就是先打印 p 个字母 然后复制 q 次,或者先打印 q 个字母,复制 p 次,结果都是一样的 p+q

在 p > 1 且 q > 1 的条件下 p*q >= p+q 永远成立,所以先打印因数个字母再复制的打印方法是最优的。

所以将n做质因数分解就可以了,比如 36=2*2*3*3 答案就是 dp[36]=dp[2]+dp[2]+dp[3]+dp[3],又知道所有的质数答案都是固定的(即该数本身),也就是说 36=2+2+3+3=10

class Solution {
public:
int minSteps(int n) {
int ans = 0;
for (int i = 2; i <= n; i++) {
while (n % i == 0) {
n /= i;
ans += i;
}
}
return ans;
}
};

LeetCode 650. 2 Keys Keyboard(只有两个键的键盘)(DP/质因数分解)的更多相关文章

  1. 【LeetCode】650. 2 Keys Keyboard 只有两个键的键盘(Python)

    作者: 负雪明烛 id: fuxuemingzhu 个人博客: http://fuxuemingzhu.cn/ 目录 题目描述 题目大意 解题方法 递归 素数分解 日期 题目地址:https://le ...

  2. [LeetCode] 650. 2 Keys Keyboard 两键的键盘

    Initially on a notepad only one character 'A' is present. You can perform two operations on this not ...

  3. [leetcode] 650. 2 Keys Keyboard (Medium)

    解法一: 暴力DFS搜索,对每一步进行复制还是粘贴的状态进行遍历. 注意剪枝的地方: 1.当前A数量大于目标数量,停止搜索 2.当前剪贴板数字大于等于A数量时,只搜索下一步为粘贴的状态. Runtim ...

  4. LeetCode 650 - 2 Keys Keyboard

    LeetCode 第650题 Initially on a notepad only one character 'A' is present. You can perform two operati ...

  5. [LeetCode] 651. 4 Keys Keyboard 四键的键盘

    Imagine you have a special keyboard with the following keys: Key 1: (A): Print one 'A' on screen. Ke ...

  6. Java实现 LeetCode 650 只有两个键的键盘(递归 || 数学)

    650. 只有两个键的键盘 最初在一个记事本上只有一个字符 'A'.你每次可以对这个记事本进行两种操作: Copy All (复制全部) : 你可以复制这个记事本中的所有字符(部分的复制是不允许的). ...

  7. Leetcode 650.只有两个键的键盘

    只有两个键的键盘 最初在一个记事本上只有一个字符 'A'.你每次可以对这个记事本进行两种操作: Copy All (复制全部) : 你可以复制这个记事本中的所有字符(部分的复制是不允许的). Past ...

  8. 【LeetCode】650. 只有两个键的键盘

    只有两个键的键盘 最初在一个记事本上只有一个字符 'A'.你每次可以对这个记事本进行两种操作: 1.Copy All (复制全部) : 你可以复制这个记事本中的所有字符(部分的复制是不允许的). 2. ...

  9. LC 650. 2 Keys Keyboard

    Initially on a notepad only one character 'A' is present. You can perform two operations on this not ...

  10. [Swift]LeetCode650. 只有两个键的键盘 | 2 Keys Keyboard

    Initially on a notepad only one character 'A' is present. You can perform two operations on this not ...

随机推荐

  1. httpclient,轻量级idea集成测试工具

    优点:不用新开一个网页,具有测试数据保存功能,不需要配置即用(对比swagger)     不会特别占内存(对比postman) 使用方法:idea中安装插件 controller方法中点击 选择对应 ...

  2. docker dockerfile基础指令

    dockerfile是用来构建docker镜像文件!命令参数脚本 构建步骤 1.编写一个dockerfile文件 2.dockerbuild构建成为一个镜像 3.docker run运行镜像 4.do ...

  3. Jmeter的安装(Windows)

    1.选择和本机JDK兼容的jmeter版本下载 Jmeter历史版本下载地址:https://archive.apache.org/dist/jmeter/binaries/ 此处我的jmeter5. ...

  4. 【JavaWeb】 接口鉴权

    一年前写过一篇,叫Webservice校验机制,叫法不太对,就是接口鉴权 https://www.cnblogs.com/mindzone/p/15078436.html 这东西就是说,你提供给外部的 ...

  5. 【Win10】找不到Telnet命令

    百度才发现原来我的Telnet程序就没启动... CMD终端就找不到命令... 但是有一点要注意!不能使用CMD之外的终端访问[GitBash访问无效] 打开控制面板,点卸载程序: 然后点击启动和关闭 ...

  6. python性能分析器:cProfile

    代码: (1) import cProfile import re cProfile.run('re.compile("foo|bar")') 运行结果: (2) import c ...

  7. AI机器人——人形机器人、双足机器人、四足机器人 —— 组成构建有哪些?

    参考: https://www.youtube.com/watch?v=dLELvoFt_iA

  8. python运行报错:ImportError: libcudnn_cnn_infer.so.8: cannot open shared object file

    运行报错: 解决方法: conda install cudatoolkit==11.8.0 python3 -m pip install nvidia-cudnn-cu11==8.7.0.84 成功解 ...

  9. 不符合自身利益的科学讨论是否应该得到尊重—— 读《自家员工质疑Jeff Dean领衔的Nature论文被解雇,谷歌:我们彻查了,质疑不符合标准》有感

    读了一篇博文<自家员工质疑Jeff Dean领衔的Nature论文被解雇,谷歌:我们彻查了,质疑不符合标准>,其问大致是说Google提了一篇使用reinforcement learnin ...

  10. Error in v-on handler: "TypeError: Cannot read property 'value' of undefined"

    Error in v-on handler: "TypeError: Cannot read property 'value' of undefined" 报错如下所示,即 在运行 ...