【Python】使用集合实现筛选法求素数实验

使用集合实现筛选法求素数实验

题目:

输入一个大于 2 的自然数,输出小于该数字的所有素数组成的集合。

实现步骤:

  1. 首先,创建一个包含所有自然数(从2到您输入的自然数)的集合,称为numbers集合。
  2. 创建一个空的集合,用于存储素数,称为prime_numbers集合。
  3. 从2开始,遍历numbers集合中的每个数字:
    • 如果当前数字是素数,则将它添加到prime_numbers集合中。
    • 然后,从numbers集合中删除当前素数的所有倍数,因为它们不可能是素数。
  4. 重复步骤3,直到遍历完numbers集合中的所有数字。
  5. 最后,prime_numbers集合将包含小于您输入的自然数的所有素数。

参考代码:

python 复制代码
# 输入一个大于2的自然数
n = int(input("请输入一个大于2的自然数:"))
if n <= 2:
    print("请输入大于2的自然数。")
else:
    # 创建一个包含所有自然数的集合
    numbers = set(range(2, n + 1))
    prime_numbers = set()

    while numbers:
        current = min(numbers)
        prime_numbers.add(current)
        numbers -= set(range(current, n + 1, current))

    print("小于", n, "的所有素数组成的集合:", prime_numbers)

代码解释:

  1. 我们设定输入数字 n 为 10。

  2. 我们创建一个包含所有自然数的集合 numbers,从2到10,即 {2, 3, 4, 5, 6, 7, 8, 9, 10}

  3. 我们创建一个空集合 prime_numbers,用于存储素数。

  4. 进入循环,首先选取 currentnumbers 集合中的最小数字,即 2。

  5. 我们将 2 添加到 prime_numbers 集合中,并从 numbers 集合中删除2的所有倍数。此时,prime_numbers 变成 {2}numbers 变成 {3, 5, 7, 9}

  6. 重复这个过程,下一个最小数字是3,将其添加到 prime_numbers 集合中,并删除3的倍数。此时,prime_numbers 变成 {2, 3}numbers 变成 {5, 7}

  7. 继续这个过程,一直到 numbers 集合为空。

  8. 最后,程序将输出小于10的所有素数组成的集合:{2, 3, 5, 7}

相关推荐
Dontla5 分钟前
Python Streamlit介绍(开源Python Web应用框架,快速将Python脚本转换成交互式Web应用,适合数据科学和机器学习项目快速展示)
前端·python·开源
少云清25 分钟前
【UI自动化测试】12_web自动化测试 _验证码处理和cookie
前端·python·web自动化测试
Ama_tor36 分钟前
Flask |零基础进阶(上)
后端·python·flask
喵手39 分钟前
Python爬虫实战:数字时光机 - 基于 Playwright 的网页全貌归档系统(HTML + 截图)(附CSV导出 + SQLite持久化存储)!
爬虫·python·爬虫实战·playwright·零基础python爬虫教学·csv导出·网页全貌归档
@陈小鱼44 分钟前
基于 Savitzky-Golay滤波器的超声图像运动分析方法
python·计算机视觉·matlab·信号处理
七夜zippoe1 小时前
属性测试革命:Hypothesis框架深度实战指南
python·性能测试·数据驱动·hypothesis·状态机测试
艾醒(AiXing-w)1 小时前
技术速递——通义千问 3.5 深度横评:纸面超越 GPT‑5.2,实测差距在哪?
人工智能·python·语言模型
喵手2 小时前
Python爬虫实战:自动化构建 arXiv 本地知识库 - 从 PDF 下载到元数据索引!
爬虫·python·自动化·arxiv·本地知识库·pdf下载·元数据索引
百锦再2 小时前
Java InputStream和OutputStream实现类完全指南
java·开发语言·spring boot·python·struts·spring cloud·kafka
闲人编程2 小时前
Celery分布式任务队列
redis·分布式·python·celery·任务队列·异步化