用 JavaScript 构建第一个 n 个自然数的词典序递增序列
问题
我们要求编写一个 JavaScript 函数,该函数输入一个数字 n,返回包含前 n 个自然数的数组。
唯一的要求是数字应按照词典顺序排列,这意味着所有以 1 开头的数字都应排在以 2 或 3 或 4 开头的数字前面,依此类推。
示例
以下是代码 −
const num = 24;
const buildLexicographically = (num = 1) => {
const res = [];
const curr = num >= 9 ? 9 : num;
for (let i = 1; i <= curr; i++) {
res.push(i);
for (let j = i * 10; j<=num; j++) {
res.push(j)
if(j % 10 === 9){
break;
}
}
};
return res;
};
console.log(buildLexicographically(num));输出
以下是控制台输出 −
[ 1, 10, 11, 12, 13, 14, 15, 16, 17, 18, 19, 2, 20, 21, 22, 23, 24, 3, 4, 5, 6, 7, 8, 9 ]
广告
数据结构
网络
RDBMS
操作系统
Java
iOS
HTML
CSS
Android
Python
C 编程
C++
C#
MongoDB
MySQL
Javascript
PHP