Computer >> คอมพิวเตอร์ >  >> การเขียนโปรแกรม >> Javascript

การสร้างลำดับของ first n look และพูดตัวเลขใน JavaScript


ปัญหา

ในทางคณิตศาสตร์ ลำดับ look-and-say คือลำดับของจำนวนเต็มที่เริ่มต้นดังนี้ −

1, 11, 21, 1211, 111221, 312211, …

ในการสร้างสมาชิกของลำดับจากสมาชิกก่อนหน้า เราอ่านตัวเลขของสมาชิกก่อนหน้า นับจำนวนหลักในกลุ่มของตัวเลขเดียวกัน

ตัวอย่างเช่น ตัวเลขถัดไปถึง 1211 คือ −

111221

เพราะถ้าเราอ่านหลัก 1211 ให้ดังกว่านี้จะเป็น -

One one, one two, two one which gives us 111221

เราจำเป็นต้องเขียนฟังก์ชัน JavaScript ที่รับค่าตัวเลข n และคืนค่า 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'
]