题解 | #整数中1出现的次数(从1到n整数中1出现的次数)#

整数中1出现的次数(从1到n整数中1出现的次数)

http://www.nowcoder.com/practice/bd7f978302044eee894445e244c7eee6

暴力法,遍历从1道n的数,对每个数字计算1的个数。
时间复杂度O(nlogn),空间复杂度O(1)。

class Solution {
public:
    int NumberOf1Between1AndN_Solution(int n) {
        int count = 0;
        for(int i = 1;i <= n;i++){
            int index = i;
            while(index){
                if(index%10 == 1){
                    count++;
                }
                index /= 10;
            }
        }
        return count;
    }
};



在别人的做法中看到时间复杂度为O(logn),空间复杂度为O(1)的做法。
这种做法的思想还是需要花点时间去理解的(对我来说),我将核心逻辑的注释写在下面的代码中,多少能帮助理解。

在写下面代码时被取模运算迷惑了,算是十分低级的基础不牢。任何数对1取模必然为0,因为任何数除以1都不会产生余数,而一个数对比他大的数取模则等于他自身。

class Solution {
public:
    int NumberOf1Between1AndN_Solution(int n) {
        int base = 1;//当前位数, 从个位开始
        int count = 0;
        while(n / base){
            int cur = n / base % 10;//当前位数处的值
            int higher = n / base / 10;//cur左侧数
            int lower = n % base;//cur右侧数
            if(cur == 1){//当该位为1时, 要么左侧数保持不变, 右侧数可产生lower+1个数, 要么左侧数取0~higher, 则可以借位给右侧数, 右侧数取0~base-1
                count += higher * base + lower + 1;
            }
            else if(cur == 0){//当该位为0时, 必须向左侧数借位, 左侧数取0~higher-1, 右侧数取0~base-1
                count += higher * base;
            }
            else{//当该位大于1时, 可以在不向左侧数借位的情况下借位给右侧数
                count += (higher + 1) * base;
            }
            base *= 10;
        }
        return count;
    }
};
全部评论

相关推荐

06-12 17:46
门头沟学院 Java
运营你豪哥:来说重点: ​1.项目前置,时间倒序。​​ 2.​项目描述强化结果与量化效果(STAR原则里的R)。​​ ​3.个人技能精炼,明确掌握程度,突出核心。​​ ​4.增加强有力开头的个人总结部分。​​ 5.​优化教育背景(成绩排名)、合并奖项与活动。​​
听劝,我这个简历该怎么改...
点赞 评论 收藏
分享
06-13 17:33
门头沟学院 Java
顺序不记了,大致顺序是这样的,有的相同知识点写分开了1.基本数据类型2.基本数据类型和包装类型的区别3.==和equals区别4.ArrayList与LinkedList区别5.hashmap底层原理,put操作时会发生什么6.说出几种树型数据结构7.B树和B+树区别8.jvm加载类机制9.线程池核心参数10.创建线程池的几种方式11.callable与runnable区别12.线程池怎么回收线程13.redis三剑客14.布隆过滤器原理,不要背八股,说说真正使用时遇到了问题没有(我说没有,不知道该怎么回答了)15.堆的内存结构16.自己在写项目时有没有遇见过oom,如何处理,不要背八股,根据真实经验,我说不会17.redis死锁怎么办,watchdog机制如何发现是否锁过期18.如何避免redis红锁19.一个表性别与年龄如何加索引20.自己的项目的QPS怎么测的,有没有真正遇到大数量表21.说一说泛型22.springboot自动装配原理23.springmvc与springboot区别24.aop使用过嘛?动态代理与静态代理区别25.spring循环依赖怎么解决26.你说用过es,es如何分片,怎么存的数据,1000万条数据怎么写入库中27.你说用limit,那么在数据量大之后,如何优化28.rabbitmq如何批次发送,批量读取,答了延迟队列和线程池,都不对29.计网知不知道smtp协议,不知道写了对不对,完全听懵了30.springcloud知道嘛?只是了解反问1.做什么的?短信服务,信息量能到千万级2.对我的建议,基础不错,但是不要只背八股,多去实际开发中理解。面试官人不错,虽然没露脸,但是中间会引导我回答问题,不会的也只是说对我要求没那么高。面完问我在济宁生活有没有困难,最快什么时候到,让人事给我聊薪资了。下午人事打电话,问我27届的会不会跑路,还在想办法如何使我不跑路,不想扣我薪资等。之后我再联系吧,还挺想去的😭,我真不跑路哥😢附一张河科大幽默大专图,科大就是大专罢了
查看30道真题和解析
点赞 评论 收藏
分享
不愿透露姓名的神秘牛友
07-01 17:13
想去,但是听说加班强度实在难崩,所以拒绝了,现在有点心梗对面hr感觉也是实习生,打电话的时候怪紧张的,但是感觉人很好嘞
水中水之下水道的鼠鼠:哥们这不先去体验一下,不行再跑呗,大不了混个实习经历(有更好的转正offer就当我没说)
点赞 评论 收藏
分享
评论
1
收藏
分享

创作者周榜

更多
牛客网
牛客网在线编程
牛客网题解
牛客企业服务