开启辅助访问 切换到宽版

精易论坛

 找回密码
 注册

QQ登录

只需一步,快速开始

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

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


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

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

查看: 1213|回复: 65
收起左侧

[易语言纯源码] 数组去重复,再比原来快一倍,数组排序用了归并算法

[复制链接]
结帖率:75% (3/4)
发表于 3 天前 | 显示全部楼层 |阅读模式   福建省福州市
分享源码
界面截图:
是否带模块: -
备注说明: -
本帖最后由 APPLEUFO 于 2025-6-23 09:50 编辑

https://bbs.125.la/forum.php?mod=viewthread&tid=14712534&extra=  
前面那帖子,排序后去重复

原来是文本的快速排序后,再循环对比

现在弄出文本的归并排序后,再循环对比了

文本的归并排序比 快速排序,快了3-5倍吧,速度也就又提起来了

  
子程序名返回值类型公开备 注
数组模块_去重复7_排序后对比 排序过的   (1122334)(1234),也是非常快的,不输给去重复6。
参数名类 型参考可空数组备 注
参数_文本文本型
参数_重复数组文本型
变量名类 型静态数组备 注
局变_原始文本开始的下标整数型跳转到下回开始对比的下标
n1整数型循环用
m1整数型重复数组的下标
如果真 (取数组成员数 (参数_文本) < 2)    参数_重复数组 = 参数_文本
返回 ()

' 数组模块_快速排序_文本 (参数_文本, )
排序模块_归并排序_迭代版_文本 (参数_文本, )
重定义数组 (参数_重复数组, 假, 取数组成员数 (参数_文本))
局变_原始文本开始的下标 = 1
循环判断首 ()
变量循环首 (局变_原始文本开始的下标, 取数组成员数 (参数_文本) - 1, 1, n1)  ' 假定他现在前面几个都是重复的,开局就用变量循环
如果 (参数_文本 [n1] = 参数_文本 [n1 + 1])
' 调试输出 (参数_文本 [n1], 参数_文本 [n1 + 1], “===”)
' 相等  无动作


' 调试输出 (参数_文本 [n1], 参数_文本 [n1 + 1], “=!==!”)
m1 = m1 + 1
参数_重复数组 [m1] = 参数_文本 [n1]  ' 不相等的上一个加入去重复
局变_原始文本开始的下标 = n1 + 1  ' 不相等的下一个 跳转进去。把变量循环的开始值设置成它
' 调试输出 (m1, 局变_原始文本开始的下标, 参数_文本 [n1], “-------------------”)
跳出循环 ()

变量循环尾 ()
' 调试输出 (n1, “=============================”)
如果真 (n1 = 取数组成员数 (参数_文本))  ' 下标等于最后一个,它没办法和下一个比较了。就添加到去重复数组了
' 调试输出 (n1, 局变_原始文本开始的下标, , , 666)
m1 = m1 + 1
参数_重复数组 [m1] = 参数_文本 [局变_原始文本开始的下标]  ' 局变_原始文本开始的下标  最后两种情况,相邻的两个相等或者不相等
跳出循环 ()

循环判断尾 ()
重定义数组 (参数_重复数组, 真, m1)
' 不明白的是明明比6更紧凑,用的变量也少。还是不能大幅跑赢6///2025.6.19





至于整数型的去重复,直接用桶排序,测试速度比精益现在内置的的更快了


  
子程序名返回值类型公开备 注
数组模块_去重复桶排序_整数型 因为是桶排序,所以极限是1-整数型最大(长整数型也行)
参数名类 型参考可空数组备 注
参数_原始数组整数型
参数_结果数组整数型
变量名类 型静态数组备 注
局变_最大数整数型 
局变_桶子整数型0根据 局变_最大数  定义需要 多少个桶子、、  
n1整数型 
m1整数型 
计次循环首 (取数组成员数 (参数_原始数组), n1)  ' 找数组里面最大的数
如果真 (局变_最大数 < 参数_原始数组 [n1])
局变_最大数 = 参数_原始数组 [n1]

计次循环尾 ()
' 调试输出 (局变_最大数, “局变_最大数”)
重定义数组 (局变_桶子, 假, 局变_最大数)  ' 从 1 --- 最大值
计次循环首 (取数组成员数 (参数_原始数组), n1)
' 局变_临时 = 参数_原始数组 [n1]
局变_桶子 [参数_原始数组 [n1]] = 1
计次循环尾 ()
重定义数组 (参数_结果数组, 假, 取数组成员数 (参数_原始数组))
计次循环首 (取数组成员数 (局变_桶子), n1)
如果 (局变_桶子 [n1] = 0)



m1 = m1 + 1
参数_结果数组 [m1] = n1

计次循环尾 ()
重定义数组 (参数_结果数组, 真, m1)
子程序名返回值类型公开备 注
数组模块_验证是否有重复_整数逻辑型 有返回假 否则真   没有重复返回真
参数名类 型参考可空数组备 注
参数_整数数组整数型
变量名类 型静态数组备 注
n1整数型 
m1整数型 
数组排序 (参数_整数数组, )
计次循环首 (取数组成员数 (参数_整数数组) - 1, n1)
' 调试输出 (参数_整数数组 [n1], 参数_整数数组 [n1 + 1], 666)
如果 (参数_整数数组 [n1] = 参数_整数数组 [n1 + 1])
返回 ()


' 继续无动作

计次循环尾 ()
返回 ()

10.8.e

306.99 KB, 下载次数: 43, 下载积分: 精币 -2 枚

点评

有没有可能,去掉排序后更快。或者说你去重后再排序更快   山东省滨州市  发表于 4 小时前

评分

参与人数 23好评 +2 精币 +26 收起 理由
jc520hll + 1 感谢分享,很给力!~
z134 + 1 感谢分享,很给力!~
ma4747 + 1 感谢分享,很给力!~
cbl521ysys + 1 感谢分享,很给力!~
无尘666 + 1 感谢分享,很给力!~
3266167 + 1 感谢分享,很给力!~
huangdi9569 + 1 感谢分享,很给力!~
pj小黑屋 + 1 感谢分享,很给力!~
liy456 + 1 感谢分享,很给力!~
文西哥 + 1 感谢分享,很给力!~
望尘莫及 + 1 感谢分享,很给力!~
暮光之城 + 1 感谢分享,很给力!~
初阳123 + 1 感谢分享,很给力!~
浮梦 + 1 感谢分享,很给力!~
475837991 + 1 感谢分享,很给力!~
Zźh926 + 1 感谢分享,很给力!~
huangdi956 + 1 感谢分享,很给力!~
洛哥 + 1 感谢分享,很给力!~
YunXiGe + 1 感谢分享,很给力!~
cunanhai + 1 + 2 支持开源~!感谢分享
kyo9766 + 1 感谢分享,很给力!~
李泽勇2 + 1 + 3 感谢分享,很给力!~
malin158 + 1 感谢分享,很给力!~

查看全部评分


签到天数: 25 天

发表于 2 小时前 | 显示全部楼层   山东省青岛市
大神,请收下我的膝盖,膜拜你,真的很厉害!
回复 支持 反对

使用道具 举报

结帖率:0% (0/2)

签到天数: 22 天

发表于 3 小时前 | 显示全部楼层   广西壮族自治区玉林市
感谢分享
回复 支持 反对

使用道具 举报

结帖率:75% (3/4)

签到天数: 15 天

 楼主| 发表于 3 小时前 | 显示全部楼层   福建省福州市
笨来无一悟 发表于 2025-6-24 04:01
整数 要看范围 小范围 比如最大值不超一千万的 用位图最快

我昨天试了一下  
还没写出来。就遇到几个问题
怀疑就算写出来了未必比桶排序快。省内存是没问题的
问题是现在的电脑不缺内存,宝贵的是时间  


我能想到这个位图算法费时间的点就是:他没办法以二进制存在数组长整数或字节里。所以是字节型数存储的.还是一个整数   

那么我修改未排序的 320   5    888  20    70,这几个位图地址的时候,那么  例如 5   和  20  

就得先读取第一格  1-64格的数组值。 然后修改第5格的二进制,然后保存
到了20 的时候,还得再读取第一个整数值,找到20格修改,再保存
就算5和20是相邻的。也没办法读取一次  修改一次,保存一次

1读取整数,2转换二进制,3修改二进制,4转换成十进制   
每修改一格的0和1,就得来上面4步,这样一次
肯定得耗费大量时间

回复 支持 反对

使用道具 举报

结帖率:75% (3/4)

签到天数: 15 天

 楼主| 发表于 4 小时前 | 显示全部楼层   福建省福州市
你不丑 发表于 2025-6-24 15:17
哦哦 那可能不是精易模块的吧 我记错了 不好意思

一楼整数去重,桶排序的那个代码,我测试已经比精益模块的代码更快了,你可以试试看  按自己需要测试下速度怎么样
回复 支持 反对

使用道具 举报

结帖率:96% (119/124)

签到天数: 25 天

发表于 4 小时前 | 显示全部楼层   山东省青岛市
感谢楼主分享!
回复 支持 反对

使用道具 举报

结帖率:96% (55/57)

签到天数: 25 天

发表于 5 小时前 | 显示全部楼层   山东省青岛市
全都是大佬~
回复 支持 反对

使用道具 举报

结帖率:100% (2/2)

签到天数: 25 天

发表于 昨天 20:00 | 显示全部楼层   广东省东莞市
这个好,要的就是一个字:快
回复 支持 反对

使用道具 举报

结帖率:100% (7/7)

签到天数: 18 天

发表于 昨天 19:26 | 显示全部楼层   湖北省咸宁市
感谢分享,很给力!~
回复 支持 反对

使用道具 举报

结帖率:0% (0/2)

签到天数: 17 天

发表于 昨天 15:26 | 显示全部楼层   广西壮族自治区南宁市
感谢分享,很给力!~
回复 支持 反对

使用道具 举报

签到天数: 19 天

发表于 昨天 15:19 | 显示全部楼层   广东省深圳市
纯易代码,不嵌入汇编还是太慢
回复 支持 反对

使用道具 举报

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

本版积分规则 致发广告者

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

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

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