報數序列是一個整數序列,按照其中的整數的順序進行報數,得到下一個數。其前五項如下:
1. 1
2. 11
3. 21
4. 1211
5. 111221
1 被讀作 “one 1” (“一個一”) , 即 11。
11 被讀作 “two 1s” (“兩個一”), 即 21。
21 被讀作 “one 2”, “one 1” (“一個二” , “一個一”) , 即 1211。
給定一個正整數 n(1 ≤ n ≤ 30),輸出報數序列的第 n 項。
注意:整數順序將表示爲一個字符串。
示例 1:
輸入: 1
輸出: "1"
示例 2:
輸入: 4
輸出: "1211"
代碼
/**
* @param {number} n
* @return {string}
*/
var countAndSay = function(n) {
if(n==1){
return "1";
}
let number = "1";
let result = '';
for(let i=2;i<=n;i++){
let count = 1;
result = '';
for(let i=0; i<number.length; i++){
if(number[i] !== number[i+1]){
result += `${count}${number[i]}`
count = 1;
}else{
count ++;
}
}
number = result;
}
return result;
};