• 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. }

  • 相关阅读:
    【基础】Springboot处理事务@Transactional
    电商后台项目 + 源码
    基于Java电动车上牌管理系统计实现(源码+lw+部署文档+讲解等)
    arcPy与添加 shp 文件(显示在 ArcMap),通过Arcpy打开mxd文档并添加数据的方式
    spring ioc源码解读
    命令行远程操作windows
    无代码开发平台权限设置入门教程
    输入spark-shell后毫无反应直接跳出命令行
    android: Preferences DataStore 和 Proto DataStore use guide
    ActiveMQ面试题(一)
  • 原文地址:https://blog.csdn.net/kku101xyz/article/details/126923008