开启辅助访问 切换到宽版

精易论坛

 找回密码
 注册

QQ登录

只需一步,快速开始

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

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


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

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

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

[易语言纯源码] 纯数组去重复1千万3秒1亿30秒,如此类推,不论重复量多少都一样。

[复制链接]
结帖率:93% (14/15)
跳转到指定楼层
楼主
发表于 2013-5-4 21:05:53 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式   广东省佛山市
分享源码
界面截图:
是否带模块: -
备注说明: 易语言核心库。
本帖最后由 yjwfdc 于 2013-5-5 13:20 编辑

纯数组去重复1千万3秒1亿30秒,如此类推,不论重复量多少都一样。
如果成员数比较大,不要点显示,显示会很慢很慢的。只点“加入数组”和“去重复”就可以了。
飘逸纯数组去重算法1千万3秒。x.rar (3.52 KB, 下载次数: 710)

一百万成员卡介面0.3秒,一千万成员数组才会卡介面3秒。
这只是原理,使用的时候是应该用线程的。

修改了一下,内存占用少了一半,把排序时间和去重复时间分开显示,时间主要用在排序,1亿排序用了27秒,去重复只需要3秒.
加入一个数组写出模块,写出1千万数组到文件需时约10秒,写出1亿数组需时约100秒。
不好意思,原来那个计错数了,少输出了一个。

不重发付件了,只更新了付件。



补充内容 (2018-8-9 23:09):
是纯数数组去重复,不支持文本,标题打少了一个"数"字。

结帖率:45% (25/56)
沙发
发表于 2013-5-4 21:07:00 | 只看该作者   山西省太原市
这么牛逼的东西必须拿走
回复 支持 反对

使用道具 举报

结帖率:62% (26/42)
板凳
发表于 2013-5-4 21:17:25 | 只看该作者   广东省东莞市
运行的时候太卡了。。

建议 使用命令    启动线程


.版本 2
.支持库 EThread
.支持库 commobj

.程序集 窗口程序集1
.程序集变量 原数组, 整数型, , "0"
.程序集变量 结果数组, 整数型, , "0"
.程序集变量 成员数, 长整数型
.程序集变量 k, 整数型

.子程序 _加入数组按钮_被单击

启动线程 (&子程序_加入数组, , )


.子程序 子程序_加入数组
.局部变量 i, 整数型

成员数 = 到数值 (编辑框2.内容)
置随机数种子 (取启动时间 ())
重定义数组 (原数组, 假, 成员数)
.计次循环首 (成员数, i)
    原数组 [i] = 取随机数 (0, 成员数 ÷ 10) × 取随机数 (0, 成员数 ÷ 10) + 取随机数 (0, 成员数 ÷ 10)
.计次循环尾 ()
信息框 (“成员数” + 到文本 (成员数), 0, )



.子程序 _显示数组按钮_被单击

启动线程 (&子程序_显示数组, , )

.子程序 _显示按钮_被单击

启动线程 (&子程序_显示, , )

.子程序 子程序_显示
.局部变量 i, 整数型
.局部变量 快速文本, 快速文本对象

k = 取启动时间 ()
编辑框1.内容 = “”
.计次循环首 (取数组成员数 (结果数组), i)
    快速文本.添加 (到文本 (结果数组 [i]) + #换行符)
.计次循环尾 ()
编辑框1.内容 = 快速文本.取文本 (, )
编辑框1.加入文本 (“快速文本显示用时” + 到文本 (取启动时间 () - k) + #换行符)


.子程序 子程序_显示数组
.局部变量 i, 整数型
.局部变量 文件号, 整数型
.局部变量 文本, 文本型

k = 取启动时间 ()
文件号 = 打开内存文件 ()
.计次循环首 (成员数, i)
    写文本行 (文件号, 原数组 [i])
.计次循环尾 ()
移到文件首 (文件号)
文本 = 读入文本 (文件号, )
关闭文件 (文件号)

编辑框1.内容 = 文本
编辑框1.加入文本 (“内存文件显示用时” + 到文本 (取启动时间 () - k) + #换行符)


.子程序 _去重复按钮_被单击

启动线程 (&子程序_去重复, , )

.子程序 子程序_去重复
.局部变量 成员数, 整数型
.局部变量 i, 长整数型
.局部变量 a, 整数型
.局部变量 记录位置, 整数型

k = 取启动时间 ()
数组排序 (原数组, 真)
成员数 = 取数组成员数 (原数组)
重定义数组 (结果数组, 假, 成员数)

i = 0
记录位置 = 1
.判断循环首 (记录位置 ≤ 成员数)
    i = i + 1
    结果数组 [i] = 原数组 [记录位置]
    .循环判断首 ()
        记录位置 = 记录位置 + 1
        .如果真 (记录位置 > 成员数)
            跳出循环 ()
        .如果真结束

    .循环判断尾 (结果数组 [i] = 原数组 [记录位置])
.判断循环尾 ()

成员数 = i - 1
重定义数组 (结果数组, 真, 成员数)
编辑框1.加入文本 (“不重复数” + 到文本 (成员数))
编辑框1.加入文本 (“去重复用时” + 到文本 (取启动时间 () - k) + #换行符)

回复 支持 反对

使用道具 举报

结帖率:93% (14/15)
地板
 楼主| 发表于 2013-5-4 21:39:48 | 只看该作者   广东省佛山市
本帖最后由 yjwfdc 于 2013-5-4 21:44 编辑
陈小胖 发表于 2013-5-4 21:17
运行的时候太卡了。。

建议 使用命令    启动线程

一百万成员卡介面0.3秒,一千万成员数组才会卡介面3秒。

这只是原理,使用的时候是应该用线程的。

点评

求源码里面的模块开源。。。   广东省江门市  发表于 2016-6-9 15:21
回复 支持 反对

使用道具 举报

结帖率:100% (9/9)
地下
发表于 2013-5-4 21:56:26 | 只看该作者   广东省云浮市
拿下了 谢谢楼主~
回复 支持 反对

使用道具 举报

结帖率:93% (14/15)
6
 楼主| 发表于 2013-5-5 13:20:17 | 只看该作者   广东省佛山市
修改了一下,内存占用少了一半,把排序时间和去重复时间分开显示,时间主要用在排序,1亿排序用了27秒,去重复只需要3秒.
加入一个数组写出模块,写出1千万数组到文件需时约10秒,写出1亿数组需时约100秒。
不好意思,原来那个计错数了,少输出了一个。
不重发付件了,只更新了付件。


回复 支持 反对

使用道具 举报

结帖率:100% (4/4)
7
发表于 2013-5-9 18:05:52 | 只看该作者   湖北省武汉市
看看,什么情况
回复 支持 反对

使用道具 举报

结帖率:37% (7/19)
8
发表于 2013-5-12 11:18:47 | 只看该作者   北京市北京市
看下了         
回复 支持 反对

使用道具 举报

结帖率:0% (0/2)
9
发表于 2013-5-16 07:53:58 | 只看该作者   江西省抚州市
看一看,学一学.
回复 支持 反对

使用道具 举报

结帖率:0% (0/1)
10
发表于 2013-5-30 09:41:13 | 只看该作者   陕西省渭南市
这个东西必须保留,以后备用
回复 支持 反对

使用道具 举报

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

本版积分规则 致发广告者

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

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

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