Computer >> Máy Tính >  >> Lập trình >> Javascript

Xây dựng một chuỗi tăng dần từ vựng của n số tự nhiên đầu tiên trong JavaScript

Vấn đề

Chúng tôi được yêu cầu viết một hàm JavaScript nhận vào một số n và trả về một mảng chứa n số tự nhiên đầu tiên.

Điều kiện duy nhất là các số phải được sắp xếp theo từ điển nghĩa là tất cả các số bắt đầu bằng 1 phải đứng trước bất kỳ số nào bắt đầu bằng 2 hoặc 3 hoặc 4, v.v.

Ví dụ

Sau đây là mã -

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));

Đầu ra

Sau đây là đầu ra của bảng điều khiển -

[
   1, 10, 11, 12, 13, 14, 15, 16,
   17, 18, 19, 2, 20, 21, 22, 23,
   24, 3, 4, 5, 6, 7, 8, 9
]