开启辅助访问 切换到宽版

精易论坛

 找回密码
 注册

QQ登录

只需一步,快速开始

用微信号发送消息登录论坛

新人指南 邀请好友注册 - 我关注人的新帖 教你赚取精币 - 每日签到


求职/招聘- 论坛接单- 开发者大厅

论坛版规 总版规 - 建议/投诉 - 应聘版主 - 精华帖总集 积分说明 - 禁言标准 - 有奖举报

查看: 2451|回复: 16
打印 上一主题 下一主题
收起左侧

[易语言纯源码] 找质数的~采用埃拉托斯特尼筛法

[复制链接]

结帖率:100% (2/2)
跳转到指定楼层
楼主
发表于 2022-8-31 09:11:49 | 只看该作者 |只看大图 回帖奖励 |倒序浏览 |阅读模式   河南省平顶山市
分享源码
界面截图:
是否带模块: 纯源码
备注说明: -
本帖最后由 亮蓝色的风 于 2022-8-31 14:42 编辑

参考 埃拉托斯特尼筛法,简称埃氏筛或爱氏筛,是一种由古希腊数学家埃拉托斯特尼所提出的一种简单检定素数的算法。要得到自然数n以内的全部素数,必须把不大于根号n的所有素数的倍数剔除,剩下的就是素数。 求质数.e (4.6 KB, 下载次数: 18) 修改了原先的一处错误,i+i 改为i×i
添加了一下平方根的方法
求质数2.e (7.43 KB, 下载次数: 11)

点评

换成20w应该就有区别了   江西省南昌市  发表于 2022-8-31 10:25
写错了吧 变量循环首 (2, 到整数 (求平方根 (总数)) + 1, 1, i)   江西省南昌市  发表于 2022-8-31 10:24

评分

参与人数 2好评 +2 精币 +3 收起 理由
易语言资源网 + 1 + 3 开源精神必须支持~
reveriexue + 1 支持开源~!感谢分享

查看全部评分


结帖率:100% (3/3)

签到天数: 16 天

沙发
发表于 2022-8-31 10:08:40 | 只看该作者   湖南省邵阳市
你的速度挺快
回复 支持 反对

使用道具 举报

结帖率:100% (2/2)

签到天数: 9 天

板凳
 楼主| 发表于 2022-8-31 11:08:02 | 只看该作者   河南省平顶山市
@l1299587332 如果用平方根的方法,标记完后还要再循环一边来取出质数。速度会略慢

  
子程序名返回值类型公开备 注
生成数集2  
变量名类 型静态数组备 注
总数整数型 
i整数型 
数集逻辑型0
局_质数整数型0
j整数型 
总数 = 到整数 (编辑框1.内容)
如果真 (总数 ≤ 0)
总数 = 20000
编辑框1.内容 = “20000”
重定义数组 (数集, 假, 总数)
调试输出 (到整数 (求平方根 (总数)) + 1, 到整数 (求平方根 (总数 + 0.5)))
变量循环首 (2, 到整数 (求平方根 (总数 + 0.5)), 1, i)
如果真 (数集 [i])
j = i × i
判断循环首 (j ≤ 总数)
数集 [j] = 真
j = j + i
判断循环尾 ()

变量循环尾 ()
变量循环首 (2, 总数, 1, i)
如果真 (数集 [i])
加入成员 (局_质数, i)

变量循环尾 ()
质数 = 局_质数


i支持库列表   支持库注释   
spec特殊功能支持库

点评

你导入编辑框不也是要循环一遍吗   江西省南昌市  发表于 2022-8-31 11:13
回复 支持 反对

使用道具 举报

结帖率:0% (0/1)
地板
发表于 2022-8-31 11:12:36 | 只看该作者   辽宁省大连市
谢谢分享
回复 支持 反对

使用道具 举报

结帖率:100% (49/49)

签到天数: 22 天

地下
发表于 2022-8-31 11:20:21 | 只看该作者   江西省南昌市
.版本 2

.子程序 生成数集2, 文本型
.参数 总数, 整数型
.局部变量 i, 整数型
.局部变量 数集, 逻辑型, , "0"
.局部变量 j, 整数型
.局部变量 result, 文本型

重定义数组 (数集, 假, 总数)
.变量循环首 (2, 到整数 (求平方根 (总数 + 0.5)), 1, i)
    j = 2 × i
    .判断循环首 (j ≤ 总数)
        数集 [j] = 真
        j = j + i
    .判断循环尾 ()
.变量循环尾 ()
.变量循环首 (2, 总数, 1, i)
    .如果真 (数集 [i] = 假)
        result = result + 到文本 (i) + “,”
    .如果真结束

.变量循环尾 ()
返回 (result)

你试试这个导入20w
回复 支持 反对

使用道具 举报

6
发表于 2022-8-31 11:28:19 | 只看该作者   江苏省连云港市
感谢分享
回复 支持 反对

使用道具 举报

签到天数: 15 天

7
发表于 2022-8-31 11:45:49 | 只看该作者   山东省济南市
回复 支持 反对

使用道具 举报

结帖率:100% (2/2)

签到天数: 9 天

8
 楼主| 发表于 2022-8-31 11:47:46 | 只看该作者   河南省平顶山市
@l1299587332


按总数循环的方法 直接拼接文本 ,和平方根方法  这两种方式的循环次数差不多,效率不会有太大差别

评分

参与人数 1好评 +1 精币 +3 收起 理由
明天自然醒 + 1 + 3 很赞同,谢谢!

查看全部评分

回复 支持 反对

使用道具 举报

9
发表于 2022-8-31 12:48:54 | 只看该作者   江苏省连云港市
感谢分享
回复 支持 反对

使用道具 举报

签到天数: 3 天

10
发表于 2022-8-31 13:59:30 | 只看该作者   江苏省连云港市
感谢分享
回复 支持 反对

使用道具 举报

您需要登录后才可以回帖 登录 | 注册

本版积分规则 致发广告者

发布主题 收藏帖子 返回列表

sitemap| 易语言源码| 易语言教程| 易语言论坛| 易语言模块| 手机版| 广告投放| 精易论坛
拒绝任何人以任何形式在本论坛发表与中华人民共和国法律相抵触的言论,本站内容均为会员发表,并不代表精易立场!
论坛帖子内容仅用于技术交流学习和研究的目的,严禁用于非法目的,否则造成一切后果自负!如帖子内容侵害到你的权益,请联系我们!
防范网络诈骗,远离网络犯罪 违法和不良信息举报电话0663-3422125,QQ: 793400750,邮箱:[email protected]
网站简介:精易论坛成立于2009年,是一个程序设计学习交流技术论坛,隶属于揭阳市揭东区精易科技有限公司所有。
Powered by Discuz! X3.4 揭阳市揭东区精易科技有限公司 ( 粤ICP备12094385号-1) 粤公网安备 44522102000125 增值电信业务经营许可证 粤B2-20192173

快速回复 返回顶部 返回列表