網站首頁 編程語言 正文
def _odd_iter():python
n = 1
while True:
n = n + 2
yield n
def _not_divisible(n):
return lambda x: x % n > 0
def primes():
yield 2
it = _odd_iter() # 初始序列
while True:
n = next(it) # 返回序列的第一個數
yield n
it = filter(_not_divisible(n), it) # 構造新序列
# 打印1000以內的素數:
for n in primes():
if n < 1000:
print(n)
else:
break
素數:質數又稱素數。一個大于1的自然數,除了1和它自身外,不能被其他自然數整除的數叫做質數。
方法:
計算素數的一個方法是埃氏篩法:
首先,列出從2開始的所有自然數,構造一個序列:
2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 15, 16, 17, 18, 19, 20, …
第二步,取序列的第一個數2,它一定是素數,然后用2把序列的2的倍數篩掉:
3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 15, 16, 17, 18, 19, 20, …
??此時的序列是從3開始的奇數集合。
第三步,取新序列的第一個數3,它一定是素數,然后用3把序列的3的倍數篩掉:
5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 15, 16, 17, 18, 19, 20, …
第四步,取新序列的第一個數5,然后用5把序列的5的倍數篩掉:
7, 8, 9, 10, 11, 12, 13, 14, 15, 16, 17, 18, 19, 20, …
后續,不斷篩下去,就可以得到所有的素數。
原文鏈接:https://blog.csdn.net/weixin_39589455/article/details/120790721
- 上一篇:沒有了
- 下一篇:沒有了
相關推薦
- 2022-08-08 Android實現頁面跳轉_Android
- 2022-07-28 Python?Flask實現圖片上傳與下載的示例詳解_python
- 2022-06-02 Android?實例代碼帶你掌握FrameLayout_Android
- 2022-02-24 Oracle中decode函數用法_oracle
- 2022-01-20 出現SLF4J: Failed to load class “org.slf4j.impl.Stat
- 2022-04-25 C#使用NPOI導出Excel類封裝_C#教程
- 2022-06-01 python中parser.add_argument()用法實例(命令行選項、參數和子命令解析器)_
- 2022-05-25 ASP.NET?MVC+EF實現異步增刪改查_實用技巧
- 欄目分類
-
- 最近更新
-
- window11 系統安裝 yarn
- 超詳細win安裝深度學習環境2025年最新版(
- Linux 中運行的top命令 怎么退出?
- MySQL 中decimal 的用法? 存儲小
- get 、set 、toString 方法的使
- @Resource和 @Autowired注解
- Java基礎操作-- 運算符,流程控制 Flo
- 1. Int 和Integer 的區別,Jav
- spring @retryable不生效的一種
- Spring Security之認證信息的處理
- Spring Security之認證過濾器
- Spring Security概述快速入門
- Spring Security之配置體系
- 【SpringBoot】SpringCache
- Spring Security之基于方法配置權
- redisson分布式鎖中waittime的設
- maven:解決release錯誤:Artif
- restTemplate使用總結
- Spring Security之安全異常處理
- MybatisPlus優雅實現加密?
- Spring ioc容器與Bean的生命周期。
- 【探索SpringCloud】服務發現-Nac
- Spring Security之基于HttpR
- Redis 底層數據結構-簡單動態字符串(SD
- arthas操作spring被代理目標對象命令
- Spring中的單例模式應用詳解
- 聊聊消息隊列,發送消息的4種方式
- bootspring第三方資源配置管理
- GIT同步修改后的遠程分支