用 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
]

更新於: 17-Apr-2021

68 瀏覽量

開啟你的 職業生涯

透過完成課程獲得認證

開始
廣告
© . All rights reserved.