• lucky number


    题目描述

    李老师的lucky number 是3,5和7,他爱屋及乌,还把所有质因数只有3,5,7的数字认定为lucky number,比如9, 15, 21, 25等等。请聪明的你帮忙算一算小于等于x的lucky number有多少个?

    输入数据

    一个正整数x,3=

    输出数据

    小于等于x的lucky number的个数。

    分析

    1. //假设我们已经获得了一段lucky number序列
    2. // M是这段序列中的最大值
    3. // 我们希望扩充这段序列,直到M达到给定的数值那么大
    4. // 如何扩充?
    5. // 下一个lucky number一定是由当前序列中的某个数*3*5或者*7得到的
    6. // 我们把可能产生下一个lucky number的数字记为m3, m5和m7
    7. // 他们满足:
    8. // 序列中所有小于m3的数乘以3均不大于M, m3 * 3 > M
    9. // 序列中所有小于m5的数乘以5均不大于M, m5 * 5 > M
    10. // 序列中所有小于m7的数乘以7均不大于M, m7 * 7 > M
    11. // 那么下一个lucky number将会是 min{m3*3, m5*5, m7*7},我们记作new_M
    12. // 如何更新m3, m5, m7呢?
    13. // new_M <= m3*3, new_M <= m5*5, new_M <= m7*7
    14. // 如果new_M = m3*3,那么m3向后推一位,取序列中它的下一个数就可以了,m5和m7则不变
    15. // 如果new_M = m5*5或者m7*7则同理
    16. //
    17. // 考虑初始情况,我们的序列为3, 5, 7
    18. // M = 7, m3 = 3, m5 = 3, m7 = 3
    19. // new_M = 9, new_m3 = 5, new_m5 = 3, new_m7 = 3
    20. //

    代码

    1. #include
    2. #include
    3. using namespace std;
    4. int main() {
    5. long long x;
    6. cin >> x;
    7. if (x < 7) {
    8. int res = 2;
    9. x < 5 ? --res : 0;
    10. x < 3 ? --res : 0;
    11. cout << res << endl;
    12. return 0;
    13. }
    14. vector<long long> ln(0x1000); //lucky number
    15. ln[0] = 3;
    16. ln[1] = 5;
    17. ln[2] = 7;
    18. int m3 = 0, m5 = 0, m7 = 0, M = 2; //m3, m5, m7, M均为元素下标,便于处理
    19. long long N3, N5, N7, new_ln; //N3, N5, N7是m3, m5, m7对应的值
    20. while (ln[M] <= x) {
    21. N3 = ln[m3] * 3;
    22. N5 = ln[m5] * 5;
    23. N7 = ln[m7] * 7;
    24. new_ln = N3 < N5 ? N3 : N5;
    25. new_ln = N7 < new_ln ? N7 : new_ln;
    26. new_ln == N3 ? ++m3 : 0;
    27. new_ln == N5 ? ++m5 : 0;
    28. new_ln == N7 ? ++m7 : 0;
    29. ln[++M] = new_ln;
    30. }
    31. cout << M << endl;
    32. }

  • 相关阅读:
    Kubernetes 可观测性:利用 4 个开源工具
    技术架构图是什么?和业务架构图的区别是什么?
    如何配置和使用自己的私有 Docker Registry
    unity shader屏幕后处理
    户外旅行摄影手册,旅游摄影完全攻略
    C++学习笔记——C++ deque和vector的区别
    黑苹果安装跑码是什么意思?
    【不良事件上报源码】医疗安全(不良)事件管理系统
    Nginx基础组件的使用
    电脑提示d3dx9_43.dll丢失怎么解决,分享6种有效的解决方法
  • 原文地址:https://blog.csdn.net/kku101xyz/article/details/126923008