码迷,mamicode.com
首页 > 其他好文 > 详细

整数中出现1的个数

时间:2017-04-09 09:28:25      阅读:169      评论:0      收藏:0      [点我收藏+]

标签:暴力   思路   blog   discuss   https   mic   long   line   app   

题目:求出1~13的整数中1出现的次数,并算出100~1300的整数中1出现的次数?为此他特别数了一下1~13中包含1的数字有1、10、11、12、13因此共出现6次,但是对于后面问题他就没辙了。ACMer希望你们帮帮他,并把问题更加普遍化,可以很快的求出任意非负整数区间中1出现的次数。

思路:暴力?。。。。leetCode上有一个神解答。。。

暴力代码:

 public int NumberOf1Between1AndN_Solution(int n) {
          int count=0;
        StringBuffer s=new StringBuffer();
        for(int i=1;i<n+1;i++){
             s.append(i);
           }
            String str=s.toString();
           for(int i=0;i<str.length();i++){
                 if(str.charAt(i)==‘1‘)
                    count++;
            }
         return count;
}                                           

 

神解答:原文链接:https://discuss.leetcode.com/topic/18054/4-lines-o-log-n-c-java-python

public int countDigitOne(int n) {
    int ones = 0;
    for (long m = 1; m <= n; m *= 10)
        ones += (n/m + 8) / 10 * m + (n/m % 10 == 1 ? n%m + 1 : 0);
    return ones;
}

 

整数中出现1的个数

标签:暴力   思路   blog   discuss   https   mic   long   line   app   

原文地址:http://www.cnblogs.com/team42/p/6683646.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!