码农知识堂 - 1000bd
  •   Python
  •   PHP
  •   JS/TS
  •   JAVA
  •   C/C++
  •   C#
  •   GO
  •   Kotlin
  •   Swift
  • python经典百题之打印素数


    题目:找出1-N之间的所有素数,并输出所有素数.

    素数又称质数,是指只能被1和自身整除的整数,即除了1和本身以外没有其他因数的正整数。例如,2、3、5、7、11等都是素数。任何大于1的正整数都可以由素数相乘得到,因此素数具有重要的数学意义。

    方法一:暴力枚举法

    1. def is_prime(n):
    2. if n < 2:
    3. return False
    4. for i in range(2, n):
    5. if n % i == 0:
    6. return False
    7. return True
    8. def find_prime(n):
    9. prime_list = []
    10. for i in range(2, n):
    11. if is_prime(i):
    12. prime_list.append(i)
    13. return prime_list

    优点:实现简单,容易理解。

    缺点:时间复杂度较高,无法处理较大的素数范围。

    方法二:优化枚举法

    1. def find_prime(n):
    2. prime_list = []
    3. for i in range(2, n):
    4. j = 2
    5. while j <= int(i ** 0.5):
    6. if i % j == 0:
    7. break
    8. j += 1
    9. if j > int(i ** 0.5):
    10. prime_list.append(i)
    11. return prime_list

    优点:减少了部分重复计算,时间复杂度有所降低。

    缺点:仍然无法处理较大的素数范围。

    方法三:埃氏筛法

    1. def find_prime(n):
    2. prime_list = []
    3. is_prime = [True] * (n+1)
    4. for i in range(2, n+1):
    5. if is_prime[i]:
    6. prime_list.append(i)
    7. for j in range(i*i, n+1, i):
    8. is_prime[j] = False
    9. return prime_list

    优点:时间复杂度较低,可以处理较大的素数范围。

    缺点:空间复杂度较高,需要一个大小为(n+1)的数组来判断是否为素数。

    方法四:欧拉筛法

    1. def find_prime(n):
    2. prime_list = []
    3. is_prime = [True] * (n+1)
    4. for i in range(2, n+1):
    5. if is_prime[i]:
    6. prime_list.append(i)
    7. for j in range(len(prime_list)):
    8. if i * prime_list[j] > n:
    9. break
    10. is_prime[i * prime_list[j]] = False
    11. if i % prime_list[j] == 0:
    12. break
    13. return prime_list

    优点:时间复杂度较低,空间复杂度较低。

    缺点:实现较为复杂,需要对已知素数进行筛选。

  • 相关阅读:
    从没想过,质检居然这么简单
    openssl websockets
    el-menu入门学习
    Qt之分类导航主界面
    300dpi等于多少分辨率?如何给图片修改分辨率大小?
    强制缓存和协商缓存的区别是什么?对称、非对称加密的区别是什么?
    将vue项目打包成安卓app
    信贷业务中一大最重要的指标数据测算
    个体诊所电子处方模板,佳易王药店电子处方系统门诊病历软件教程
    数据结构-例题实训作业-二叉树相关
  • 原文地址:https://blog.csdn.net/yechuanhui/article/details/132852726
  • 最新文章
  • 攻防演习之三天拿下官网站群
    数据安全治理学习——前期安全规划和安全管理体系建设
    企业安全 | 企业内一次钓鱼演练准备过程
    内网渗透测试 | Kerberos协议及其部分攻击手法
    0day的产生 | 不懂代码的"代码审计"
    安装scrcpy-client模块av模块异常,环境问题解决方案
    leetcode hot100【LeetCode 279. 完全平方数】java实现
    OpenWrt下安装Mosquitto
    AnatoMask论文汇总
    【AI日记】24.11.01 LangChain、openai api和github copilot
  • 热门文章
  • 十款代码表白小特效 一个比一个浪漫 赶紧收藏起来吧!!!
    奉劝各位学弟学妹们,该打造你的技术影响力了!
    五年了,我在 CSDN 的两个一百万。
    Java俄罗斯方块,老程序员花了一个周末,连接中学年代!
    面试官都震惊,你这网络基础可以啊!
    你真的会用百度吗?我不信 — 那些不为人知的搜索引擎语法
    心情不好的时候,用 Python 画棵樱花树送给自己吧
    通宵一晚做出来的一款类似CS的第一人称射击游戏Demo!原来做游戏也不是很难,连憨憨学妹都学会了!
    13 万字 C 语言从入门到精通保姆级教程2021 年版
    10行代码集2000张美女图,Python爬虫120例,再上征途
Copyright © 2022 侵权请联系2656653265@qq.com    京ICP备2022015340号-1
正则表达式工具 cron表达式工具 密码生成工具

京公网安备 11010502049817号