Chúng tôi được yêu cầu viết một hàm JavaScript nhận một số nguyên dương, chẳng hạn như num.
Nhiệm vụ của hàm của chúng ta là đếm tổng số số 1 xuất hiện trong tất cả các số nguyên dương cho đến n (kể cả n, nếu nó chứa bất kỳ số 1 nào).
Sau đó, hàm cuối cùng sẽ trả về số lượng này.
Ví dụ -
Nếu số đầu vào là -
const num = 31;
Sau đó, đầu ra phải là -
const output = 14;
bởi vì 1 xuất hiện trong,
1, 10, 11, 12, 13, 14, 15, 16, 17, 18, 19, 21, 31
Ví dụ
Sau đây là mã -
const num = 31;
const countOnes = (num = 1) => {
if(num <= 0 ){
return 0
};
let sum = 0
num += '';
let helper = p => {
let leftNum = 0
let rightNum = 0
let di = num[p]
if(p>0){
leftNum = parseInt(num.slice(0,p))
}
if(p+1 < num.length){
rightNum = parseInt(num.slice(p+1))
}
if(di > 1){
sum += (leftNum+1)*(10**(num.length-1-p))
} else if(di == 0){
sum += (leftNum)*(10**(num.length-1-p))
} else{
sum += (leftNum)*(10**(num.length-1-p)) + rightNum + 1
}
}
for(let i =0; i < num.length; i++){
helper(i)
};
return sum;
};
console.log(countOnes(num)); Đầu ra
Sau đây là đầu ra của bảng điều khiển -
14