被3整除

被3整除

http://www.nowcoder.com/questionTerminal/51dcb4eef6004f6f8f44d927463ad5e8

题目难度:二星
考察点:找规律
简要说明:这是一道找规律的题目,只要我们发现其中的规律,题目也就迎刃而解。

  1. 分析: 对于这道题来说,我们肯定不能直接从l到r遍历一遍,然后对于每个数判断是否能够被3整除,这样的复杂度太高,因为数据范围是10^9,所以我们考虑找规律,打表如下:
    1%3 =====> 1
    12%3 =====> 0
    123%3 =====> 0
    1234%3 =====> 1
    12345%3 =====> 0
    123456%3 =====> 0
    那么我们发现从1开始,每隔3个数就有两个数%3=0,那么从[1,x]区间有多少能被3整除的数呢?答案显然为 f(x)=2*x/3,那么从[1,r]区间中被3整除的个数就等于f(r)-f(l-1)。
  2. 复杂度:
    时间复杂度:O(1)
    空间复杂度:O(1)
  3. 代码:
    #include <bits/stdc++.h>
    using namespace std;
    int f(int x) {
     return 2*x/3;
    }
    int main() {
     int l, r; 
     while(cin>>l>>r) {
         cout<<f(r)-f(l-1)<<endl;
     }
     return 0;
    }
    
全部评论

相关推荐

给🐭🐭个面试机会...:我擦seed✌🏻
点赞 评论 收藏
分享
11-13 10:17
门头沟学院 Java
昨天面美团,jvm,juc问的好深啊,感觉小林coding不太够喔,牛油们有没有什么推荐的八股网站嘛🕒&nbsp;岗位/面试时间👥&nbsp;面试题目🤔&nbsp;面试感受
明天不下雨了:小林Coding:https://xiaolincoding.com/ 全栈哥:https://www.pdai.tech/ Guide哥:https://javaguide.cn/ 秀哥:https://interviewguide.cn/ 沉默王二:https://javabetter.cn/home.html 磊哥:https://www.javacn.site/interview/basic/ 小傅哥:https://bugstack.cn/ 源码哥:https://doocs.github.io/source-code-hunter/#/ 各大厂的公众号技术文章和一些经典的书籍
面试太紧张了怎么办?
点赞 评论 收藏
分享
评论
3
收藏
分享

创作者周榜

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