开启辅助访问 切换到宽版

精易论坛

 找回密码
 注册

QQ登录

只需一步,快速开始

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

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


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

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

楼主: APPLEUFO
打印 上一主题 下一主题
收起左侧

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

[复制链接]
结帖率:97% (31/32)
35
发表于 2025-6-23 13:15:03 | 只看该作者   福建省福州市
APPLEUFO 发表于 2025-6-23 12:09
后面跑通了,这样才看到

重定义数组 (ccc, 真, ls)

不用啊   置数组成员数 (ccc,ls)就可以了  你要是调用计次循环  .版本 2

.局部变量 ls, 整数型
.局部变量 i, 整数型

.计次循环首 (ls, i)
    调试输出 (ccc)
.计次循环尾 ()
这样都是不重复的 没有必要 把后面的去掉 调用不影响
回复 支持 反对

使用道具 举报

结帖率:97% (31/32)

签到天数: 3 天

34
发表于 2025-6-23 13:11:11 | 只看该作者   福建省福州市
cf2006a 发表于 2025-6-23 11:06
重定义 不是浪费时间 他 ls是不重复的数量重复的都放后面去了也就是ls 后面都是重复的数据 ...

没懂   数组去重 (ccc, #文本型) 你不是去文本数组吗  整数没意义  他排序是在原数组里完成
回复 支持 反对

使用道具 举报

结帖率:100% (6/6)

签到天数: 3 天

33
发表于 2025-6-23 12:58:30 | 只看该作者   新疆维吾尔自治区昌吉回族自治州
感谢分享  支持
回复 支持 反对

使用道具 举报

结帖率:75% (3/4)

签到天数: 3 天

32
 楼主| 发表于 2025-6-23 12:09:24 | 只看该作者   福建省福州市
cf2006a 发表于 2025-6-23 11:06
重定义 不是浪费时间 他 ls是不重复的数量重复的都放后面去了也就是ls 后面都是重复的数据 ...

后面跑通了,这样才看到

重定义数组 (ccc, 真, ls)
' 调试输出 (ls)
计时器结束 ()
回复 支持 反对

使用道具 举报

结帖率:97% (31/32)

签到天数: 3 天

31
发表于 2025-6-23 11:06:18 | 只看该作者   福建省福州市
APPLEUFO 发表于 2025-6-23 09:19
.版本 2

计时器启动 ()

重定义 不是浪费时间 他 ls是不重复的数量重复的都放后面去了也就是ls 后面都是重复的数据
回复 支持 反对

使用道具 举报

结帖率:70% (7/10)

签到天数: 3 天

30
发表于 2025-6-23 09:25:06 | 只看该作者   福建省泉州市
学习学习
回复 支持 反对

使用道具 举报

结帖率:100% (7/7)

签到天数: 3 天

29
发表于 2025-6-23 09:20:04 | 只看该作者   广东省广州市
感谢分享,很给力!~
回复 支持 反对

使用道具 举报

结帖率:75% (3/4)

签到天数: 3 天

28
 楼主| 发表于 2025-6-23 09:19:37 | 只看该作者   福建省福州市
本帖最后由 APPLEUFO 于 2025-6-23 09:45 编辑
cf2006a 发表于 2025-6-23 08:51
数组去重_ASM,1000万数据,毫秒级去重复,支持通用型数组
https://125.confly.eu.org/forum.php?mod=viewthread&t ...

.版本 2

计时器启动 ()
数组去重 (ccc, #整数型)
计时器结束 ()

这个代码试了一下  没跑通    得不到正确结果啊   ,咋回事  

结果素组成员 还是 原始的那么多  

=================
.版本 2

计时器启动 ()
ls = 数组去重 (ccc, #整数型)
重定义数组 (ccc, 真, ls)
' 调试输出 (ls)
计时器结束 ()


后面行了要这样   
我这里测试    桶排序比汇编还是快的。
除非他用汇编版本桶排序,才会更快

测试和精益模块对比的 汇编没跑通 .e

1 MB, 下载次数: 2, 下载积分: 精币 -2 枚

回复 支持 反对

使用道具 举报

结帖率:0% (0/2)

签到天数: 3 天

27
发表于 2025-6-23 09:11:42 | 只看该作者   广西壮族自治区玉林市
感谢分享,很给力!~
回复 支持 反对

使用道具 举报

结帖率:75% (3/4)

签到天数: 3 天

26
 楼主| 发表于 2025-6-23 09:02:29 | 只看该作者   福建省福州市
本帖最后由 APPLEUFO 于 2025-6-23 09:24 编辑
你不丑 发表于 2025-6-23 01:45
精易模块不是有汇编版本的吗 你还要写一个有啥意义呢 你比他那个还快吗

那个只能整数型去重复,对于文本型的就不行了(混合字母的也不行)    顺便问一下精益模块里的哪一条命令,精益模块11里,我 就找到了不是汇编版本的,汇编版本的没看到
用桶排序去重复,测试了速度不输精易模块的, 只能排序大于0的正整数
  
子程序名返回值类型公开备 注
数组模块_去重复桶排序_整数型 
参数名类 型参考可空数组备 注
参数_原始数组整数型
参数_结果数组整数型
变量名类 型静态数组备 注
局变_最大数整数型 
局变_桶子整数型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])
返回 ()


' 继续无动作

计次循环尾 ()
返回 ()


.版本 2

' 计时器启动 ()
' 数组_去重复_整数型 (aaa)
' 计时器结束 ()

计时器启动 ()
数组_去重复_整数型1 (bbb)
计时器结束 ()



计时器启动 ()
数组模块_去重复桶排序_整数型 (ddd, ddd_结果)
计时器结束 ()



* Windows 11
* “8 秒 734 毫秒 ”
* “453 毫秒 ”
* “218 毫秒 ”   ----------------------------------这个
* 真 | 32768
* 真 | 32768
* 真 | 32768


测试和精益模块对比的.e

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

回复 支持 反对

使用道具 举报

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

本版积分规则 致发广告者

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

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

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