开启辅助访问 切换到宽版

精易论坛

 找回密码
 注册

QQ登录

只需一步,快速开始

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

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


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

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

查看: 1770|回复: 32
收起左侧

[易语言纯源码] 7.初级例程-挑选第n小-理论上比快速排序快6倍,实际更多

[复制链接]

结帖率:100% (44/44)
发表于 2023-9-26 10:15:05 | 显示全部楼层 |阅读模式   江西省赣州市
分享源码
界面截图: -
是否带模块: -
备注说明: -
  
数据量50w
快速排序后挑选第n小
* “耗时:182.6337000001 ms”
* 10.160720
本算法挑选第n小
* “耗时:11.20310000004 ms”
* 10.160720


挑选和排序是相关的。
排序要求将整个数据数组重排,而挑选则只请求选出一个返回值:在 N 个元素中哪一个是第N个小的元素 (或等效地,第m=N+1-k大的元素)?
遗憾的是,为了挑选的计算目的、挑选的最快方法需重整数组,典型的是将所有较小的元素置于第N个元素之左,所有较大元素置于右,并且在每一个子集内顺序是杂乱的。
这种副作用轻者是无害的,重者就十分的不方便。还有一种方法不打乱原数组的顺序。这种定点挑选法比更快的方法慢约 10 倍, 本帖暂时不发。

挑选通常用于对一组数据进行统计定性。通常想知道一列数据的中间值,或上四分之一或下四分之一值。
当N是奇数时,中间值就是第N个元素,其中 k=(N+1)/2。 当N 是偶数时,统计书上定义中间值是 k=N/2和 k=N/2+1 两元素(也就是从上数第 N/2 和从下数第 N/2)的算术平均值。如果接受这种规定,就必须分别进行两次挑选,来找到这些值。对于 N>100,通常定义 k=N/2 为中间元素,不按这种规定。

若允许重排数组,最快的挑选方法则就是“划分法”,与快速排序法中探作完全相同。挑选一个“随机”分割元素,用它来核对整个序列,迫使较小的元素排列左边。较大的排到右边。正如在快速排序法中那样,优化内循环是非常重要的,使用“限制”来减少比较的数量。但在排序中,还需对分割出的两个子数组分别继续进行操作。然而在挑选中,可以略去一个子数组,而只注意包含了要找的第k元素的那一个子集。用划分法来挑选就不需要用于操作期间的堆栈,并且它的运算量是 N 量级而不是 N*log(N) 量级。

对照快速排序算法,下列例程就很容易明白。


7.挑选第n小.zip (4.55 KB, 下载次数: 64)

评分

参与人数 3好评 +3 精币 +6 收起 理由
易语言资源网 + 1 + 3 开源精神必须支持~
光影魔术 + 1 + 1 开源精神必须支持~
quary + 1 + 2 YYDS~!

查看全部评分


结帖率:85% (76/89)

签到天数: 27 天

发表于 2024-4-15 09:00:09 | 显示全部楼层   浙江省宁波市
学习了,谢谢楼主
回复 支持 反对

使用道具 举报

结帖率:100% (5/5)

签到天数: 19 天

发表于 2024-1-29 09:25:08 | 显示全部楼层   广东省佛山市
支持开源~!感谢分享
回复 支持 反对

使用道具 举报

结帖率:81% (17/21)

签到天数: 24 天

发表于 2024-1-15 20:08:12 | 显示全部楼层   河北省石家庄市
支持开源~!感谢分享
回复 支持 反对

使用道具 举报

发表于 2023-11-13 16:50:47 | 显示全部楼层   广东省中山市
感谢大神分享
回复 支持 反对

使用道具 举报

发表于 2023-10-7 04:35:34 | 显示全部楼层   广东省广州市
下载 学习!!
回复 支持 反对

使用道具 举报

结帖率:100% (1/1)
发表于 2023-10-5 19:26:41 | 显示全部楼层   河北省唐山市
很好很强悍,坚持下去哦~
回复 支持 反对

使用道具 举报

结帖率:100% (5/5)
发表于 2023-10-1 00:05:41 | 显示全部楼层   河南省商丘市
支持开源~!感谢分享
回复 支持 反对

使用道具 举报

签到天数: 25 天

发表于 2023-9-30 17:20:11 | 显示全部楼层   河北省石家庄市
感谢分享
回复 支持 反对

使用道具 举报

签到天数: 5 天

发表于 2023-9-29 17:22:44 | 显示全部楼层   广东省深圳市
感谢分享
回复 支持 反对

使用道具 举报

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

本版积分规则 致发广告者

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

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

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