
问题
在数学中,“look-and-say”序列是如下开始的整数序列 -
1, 11, 21, 1211, 111221, 312211, …
为了从前一个成员生成序列的成员,我们读出前一个成员的数字,计算相同数字组中的数字数量。
例如,下一个数字到 1211 是 -
111221
因为如果我们大声读出 1211 的数字,它会是 -
立即学习“Java免费学习笔记(深入)”;
ISite企业建站系统是为懂点网站建设和HTML技术的人员(例如企业建站人员)而开发的一套专门用于企业建站的开源免费程序。本系统采用了全新的栏目维护模式,内容添加过程中,前后台菜单是一样的,需要维护前台某个栏目的内容,只需要进后台相应栏目即可,一般的企业人员只需要查看简易的说明就可以上手维护网站内容。通过自由度极高的模板系统,可以适应大多数情况的界面需求,后台带有标签生成器,建站只需要构架好HTM
One one, one two, two one which gives us 111221
我们需要编写一个 JavaScript 函数,它接受数字 n 并返回“look thelook and say”序列的前 n 个项。
示例
以下是代码-
现场演示
const num = 12;
const generateSequence = (num = 1) => {
const lookAndSay = (val) => {
let res = '';
let chars = (val + ' ').split('');
let last = chars[0];
let count = 0;
chars.forEach(c => {
if(c === last){
count++;
}else{
res += (count + '') + last;
last = c;
count = 1;
};
});
return res;
}
let start = 1;
const res = [];
for(let i = 0; i < num; i++){
res.push(String(start));
start = lookAndSay(start);
};
return res;
};
console.log(generateSequence(num));输出
以下是控制台输出 -
[ '1', '11', '21', '1211', '111221', '312211', '13112221', '1113213211', '31131211131221', '13211311123113112211', '11131221133112132113212221', '3113112221232112111312211312113211' ]










