(劍指offer)從1到n整數中1出現次數
阿新 • • 發佈:2018-12-07
時間限制:1秒 空間限制:32768K 熱度指數:133857
題目描述
求出113的整數中1出現的次數,並算出1001300的整數中1出現的次數?為此他特別數了一下1~13中包含1的數字有1、10、11、12、13因此共出現6次,但是對於後面問題他就沒轍了。ACMer希望你們幫幫他,並把問題更加普遍化,可以很快的求出任意非負整數區間中1出現的次數(從1 到 n 中1出現的次數)。
思路1(暴力搜)
public class Solution { public int NumberOf1Between1AndN_Solution(int n) { //暴力搜尋 String str = null; int sum = 0; for(int i = 1; i <=n; i++){ str = i + ""; for(int j = 0; j < str.length(); j++){ if(str.charAt(j) == '1'){ sum++; } } } return sum; } }
思路2(暴力搜)
public class Solution {
public int NumberOf1Between1AndN_Solution(int n) {
//暴力搜尋
StringBuffer sb = new StringBuffer();
int sum = 0;
for(int i = 1; i <= n; i++){
sb.append(i);
}
String str = sb.toString();
for(int i = 0; i < str.length(); i++){
if(str.charAt(i) == '1'){
sum++;
}
}
return sum;
}
}