JavaScript 中的 2 键键盘问题
假设以下情况 −
最初记事本中只存在一个字符‘A’。我们可以在该记事本上对每一步执行两个操作−
全部复制 − 我们可以复制记事本中存在的全部字符(不允许部分复制)。
粘贴 − 我们可以粘贴上次复制的字符。
我们需要编写一个 JavaScript 函数,它将一个数字(我们称之为 num)作为唯一参数。我们的函数需要计算并返回打印‘A’ num 次所需的最小步数(全部复制或粘贴)。
例如 −
如果输入数字是 −
const num = 3;
那么输出应该是 −
const output = 3;
因为步骤是 −
全部复制(结果: ‘A’)
全部粘贴(结果: ‘AA’)
全部粘贴(结果: ‘AAA’)
示例
代码如下 −
const num = 3;
const minimumSteps = (num = 1) => {
let [curr, copy, steps] = [1, 0, 0];
while(curr != num){
if((copy < curr) && ((num - curr) % curr) == 0) {
copy = curr;
}else{
curr += copy;
};
steps += 1;
};
return steps;
};
console.log(minimumSteps(num));输出
控制台中的输出将是 −
3
广告
数据结构
网络
RDBMS
操作系统
Java
iOS
HTML
CSS
Android
Python
C 编程
C++
C#
MongoDB
MySQL
Javascript
PHP