开启辅助访问 切换到宽版

精易论坛

 找回密码
 注册

QQ登录

只需一步,快速开始

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

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


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

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

查看: 3297|回复: 5
收起左侧

[已回应] 数组_去重复_整数型

[复制链接]

结帖率:98% (48/49)
发表于 2019-6-30 08:38:19 | 显示全部楼层 |阅读模式   广东省广州市
本帖最后由 Mr.Yang 于 2019-6-30 08:40 编辑
  
子程序名返回值类型公开备 注
数组_去重复_整数型整数型 返回剩余不重复数组的成员数量
参数名类 型参考可空数组备 注
整数数组整数型要去重复的 整数数组
变量名类 型静态数组备 注
成员数整数型 
i长整数型 
a整数型 
数组排序 (整数数组, )
成员数 = 取数组成员数 (整数数组)
i = 0
a = 1
判断循环首 (a ≤ 成员数)
i = i + 1
整数数组 [i] = 整数数组 [a]
循环判断首 ()
a = a + 1
如果真 (a > 成员数)
跳出循环 ()

循环判断尾 (整数数组 [i] = 整数数组 [a])
判断循环尾 ()
重定义数组 (整数数组, 真, i)
返回 (i)

效率远比目前模块的高

评分

参与人数 2好评 +2 精币 +2 收起 理由
dwcq + 1 + 1 这不是我花钱定制后开源的吗
项目部002 + 1 + 1 感谢分享,很给力!~

查看全部评分

签到天数: 1 天

发表于 2019-7-6 11:38:52 | 显示全部楼层   广东省广州市
本帖最后由 534310554 于 2019-7-6 12:01 编辑

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

.程序集 窗口程序集_启动窗口

.子程序 _按钮1_被单击

启动线程 (&线_测试, , )

.子程序 线_测试
.局部变量 整数组, 整数型, , "10000000"
.局部变量 整数组2, 整数型, , "0"
.局部变量 计时, 整数型
.局部变量 i, 整数型

.计次循环首 (取数组成员数 (整数组), i)
    整数组  = 随机_取整数 (1, 10000)
.计次循环尾 ()
整数组2 = 整数组
调试输出 (“start”)
计时 = 取启动时间 ()
数组_去重复_整数型 (整数组)
调试输出 (取启动时间 () - 计时)
计时 = 取启动时间 ()
数组_去重复_整数型2 (整数组2)
调试输出 (取启动时间 () - 计时)
调试输出 (“end”)

.子程序 数组_去重复_整数型, 整数型, 公开, 返回剩余不重复数组的成员数量
.参数 整数数组, 整数型, 数组, 要去重复的 整数数组
.局部变量 成员数, 整数型
.局部变量 i, 长整数型
.局部变量 a, 整数型

数组排序 (整数数组, 真)
成员数 = 取数组成员数 (整数数组)
i = 0
a = 1
.判断循环首 (a ≤ 成员数)
    i = i + 1
    整数数组  = 整数数组 [a]
    .循环判断首 ()
        a = a + 1
        .如果真 (a > 成员数)
            跳出循环 ()
        .如果真结束

    .循环判断尾 (整数数组  = 整数数组 [a])
.判断循环尾 ()
重定义数组 (整数数组, 真, i)
返回 (i)

.子程序 数组_去重复_整数型2, 整数型, 公开, 返回剩余不重复数组的成员数量
.参数 整数组, 整数型, 参考 数组, 要去重复的 整数数组
.局部变量 整数组2, 整数型, , "0"
.局部变量 成员数, 整数型
.局部变量 i, 整数型
.局部变量 i2, 整数型
.局部变量 开始, 整数型
.局部变量 结束, 整数型
.局部变量 整数, 整数型

.计次循环首 (取数组成员数 (整数组), i)
    i2 = 0
    开始 = 1
    结束 = 成员数
    .判断循环首 (开始 ≤ 结束)
        i2 = 开始 + (结束 - 开始) ÷ 2
        整数 = 整数组  - 整数组2 [i2]
        .判断开始 (整数 = 0)
            跳出循环 ()
        .判断 (整数 > 0)
            开始 = i2 + 1
        .默认
            结束 = i2 - 1
        .判断结束

    .判断循环尾 ()
    .如果 (整数 = 0 且 i2 ≠ 0)
        到循环尾 ()
    .否则
        .如果真 (整数 > 0)
            i2 = i2 + 1
        .如果真结束

        .如果 (成员数 = 0)
            加入成员 (整数组2, 整数组 )
        .否则
            插入成员 (整数组2, i2, 整数组 )
        .如果结束
        成员数 = 成员数 + 1
    .如果结束

.计次循环尾 ()
整数组 = 整数组2
返回 (成员数)

##########################
试试看这段代码,你测试的速度快,很可能是数据的问题(我刚刚测试了数据是全为0的,确实能达到毫秒级),但如果涉及到超大成员的随机数据,核心库的 数组排序()就要好几秒甚至几十秒
下面是我用二分法写的去重,测试结果如下:
* 16828.000000(你的)
* 5203.000000(我的)

还有一个问题,如果 随机_取整数 (1, 10000)中的10000改为1000,你的程序直接就跑不动了,我等了几分钟都没执行完,不等了

回复 支持 反对

使用道具 举报

签到天数: 1 天

发表于 2019-7-5 13:48:27 | 显示全部楼层   广东省广州市
效率还不够高,如果数组成员有几十万几百万是不行的,可以试试二分法

点评

实测千万数组 700~1000毫秒   广东省广州市  发表于 2019-7-5 19:50
回复 支持 反对

使用道具 举报

发表于 2019-7-2 01:12:22 | 显示全部楼层   广东省东莞市
新人刷分,帮顶
回复 支持 反对

使用道具 举报

发表于 2019-7-1 10:21:22 | 显示全部楼层   广东省揭阳市
收到,感谢建议
回复 支持 反对

使用道具 举报

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

本版积分规则 致发广告者

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

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

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