开启辅助访问 切换到宽版

精易论坛

 找回密码
 注册

QQ登录

只需一步,快速开始

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

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


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

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

查看: 518|回复: 19
收起左侧

[易语言纯源码] 我和豆包写的排序排序 TimSort

[复制链接]
结帖率:75% (3/4)
发表于 昨天 23:47 | 显示全部楼层 |阅读模式   福建省福州市
分享源码
界面截图:
是否带模块: 调用了模块
备注说明: -
https://www.bilibili.com/video/BV1944y1E7as/?vd_source=95702c8745c5d28582eab4405ef02eef
介绍了一个 算法   , 插入和归并混合排序的
f阀值 32. 小于32的成员用插入,然后两两合并起来归并排序
然后我写了主框架。
000.png
让豆包把插入排序,和归并排序的部分,补上
插入排序写的十分完美。然后让它改成更快的二分插入排序   也改出来了  
  
子程序名返回值类型公开备 注
子程序_插入排序3  
参数名类 型参考可空数组备 注
参数_数组整数型
参数_左整数型
参数_右整数型
变量名类 型静态数组备 注
n1整数型 
局变_临时整数型 
m1整数型 
局变_插入点整数型 
如果 (参数_左 ≥ 参数_右)
返回 ()



调试输出 (子程序_输出指定数组成员 (参数_数组, 参数_左, 参数_右))
变量循环首 (参数_左 + 1, 参数_右, 1, n1)
局变_临时 = 参数_数组 [n1]  ' 设置插入值
局变_插入点 = -1  ' 初始化插入点
' 调试输出 (局变_临时, n1)
' 查找插入位置
变量循环首 (n1 - 1, 参数_左, -1, m1)
如果 (参数_数组 [m1] > 局变_临时)
参数_数组 [m1 + 1] = 参数_数组 [m1]  ' 元素后移
局变_插入点 = m1 + 1  ' 找到插入点
跳出循环 ()

变量循环尾 ()
' 处理最小元素的情况
如果 (局变_插入点 = -1)
局变_插入点 = 参数_左



参数_数组 [局变_插入点] = 局变_临时  ' 插入元素
' 调试输出 (子程序_输出指定数组成员 (参数_数组, 参数_左, 参数_右))
变量循环尾 ()
调试输出 (子程序_输出指定数组成员 (参数_数组, 参数_左, 参数_右))


i支持库列表   支持库注释   
spec特殊功能支持库

  
子程序名返回值类型公开备 注
子程序_二分插入排序3  
参数名类 型参考可空数组备 注
参数_数组整数型
参数_左整数型
参数_右整数型
变量名类 型静态数组备 注
n1整数型 
局变_临时整数型 
局变_左整数型 
局变_右整数型 
局变_中间整数型 
m1整数型 
' 边界检查:无需排序的情况
如果 (参数_左 ≥ 参数_右)
返回 ()



' 从第二个元素开始插入排序
变量循环首 (参数_左 + 1, 参数_右, 1, n1)
局变_临时 = 参数_数组 [n1]  ' 保存当前插入值
局变_左 = 参数_左  ' 二分查找左边界
局变_右 = n1 - 1  ' 二分查找右边界
' 二分查找插入位置
判断循环首 (局变_左 ≤ 局变_右)
局变_中间 = 局变_左 (局变_右 - 局变_左) ÷ 2  ' 避免溢出
如果 (参数_数组 [局变_中间] > 局变_临时)
局变_右 = 局变_中间 - 1  ' 目标在左半部分
局变_左 = 局变_中间 + 1  ' 目标在右半部分

判断循环尾 ()
' 元素后移(从插入位置到当前位置)
变量循环首 (n1 - 1, 局变_左, -1, m1)
参数_数组 [m1 + 1] = 参数_数组 [m1]
变量循环尾 ()
' 插入元素
参数_数组 [局变_左] = 局变_临时
变量循环尾 ()

豆包可以啊,插入排序的改版也能轻松实现  我想半天
直接输入残缺代码  他就补上了
111.png 222.png 333.png

444.png

它搞不清循环判断 和判断循环。有时候忘记循环判断尾()里加 真
555.png 666.png 777.png


然后让他补上  归并排序的代码。也整挺好,除了一点拷贝到IDE的错乱外,也能跑了
提示修改一些bug后,连主框架都改成看不懂的样子‘但是结果是没问题的
888.png

本来非常费脑子的事情   AI给解决了
用是没问题的,就是要理解代码和修改BUG就很难了

然后看看完整代码   

  
窗口程序集名保 留  保 留备 注
窗口程序集_启动窗口   
变量名类 型数组备 注
程变_临时整数型0用于归并排序的临时数组

子程序名返回值类型公开备 注
__启动窗口_创建完毕  
变量名类 型静态数组备 注
aaa整数型0
bbb整数型0
' 调试模块_创建整数型数组_无重复 (aaa, 10000000)
调试模块_创建整数型数组_有重复 (aaa, 10000000, 1, 100000)
bbb = aaa
' aaa = { 94, 29, 43, 16, 65, 80, 31, 33, 88, 92, 41, 61, 34, 52, 44, 19, 56, 4, 18, 90, 57, 38, 2, 28, 48, 32, 89, 81, 36, 69, 14, 85, 62, 24, 54, 84, 96, 9, 3, 63, 76, 82, 58, 73, 20, 93, 1, 55, 98, 67, 40, 22, 97, 51, 27, 17, 79, 77, 71, 10, 45, 74, 8, 47, 25, 12, 6, 35, 75, 83, 23, 87, 100, 60, 13, 30, 37, 78, 68, 95, 91, 53, 99, 21, 5, 26, 49, 72, 70, 50, 59, 86, 42, 46, 64, 39, 66, 11, 15, 7 }
' 调试输出 (aaa)
计时器启动 ()
子程序_新排序 (aaa)
计时器结束 ()
计时器启动 ()
排序模块_归并排序 (bbb)
计时器结束 ()
' 调试输出 (aaa)
调试输出 (调试模块_检查数组是否排序过 (aaa, ))
调试输出 (调试模块_检查数组是否排序过 (bbb, ))
结束 ()
' 全局临时数组,避免重复创建
' 全局临时数组,避免重复创建
' 全局临时数组,用于归并排序
' 全局临时数组,用于归并排序
' 全局临时数组(归并排序专用,解决跨子程序访问问题)
子程序名返回值类型公开备 注
子程序_新排序  
参数名类 型参考可空数组备 注
参数_数组整数型
变量名类 型静态数组备 注
局变_阀值整数型默认32
局变_数组个数整数型 
局变_间隔整数型 
局变_左整数型 
局变_右整数型 
局变_游标x首整数型 
局变_游标x尾整数型 
局变_游标y首整数型 
局变_游标y尾整数型 
' 初始化参数
局变_阀值 = 32
局变_数组个数 = 取数组成员数 (参数_数组)
' 空数组或单元素数组无需排序
如果 (局变_数组个数 ≤ 1)
返回 ()



' 小数组直接用二分插入排序
如果 (局变_数组个数 < 局变_阀值)
子程序_二分插入排序3 (参数_数组, 1, 局变_数组个数)
返回 ()



' 初始化临时数组(大小与原数组一致)
重定义数组 (程变_临时, 假, 局变_数组个数)
' 第一阶段:按阀值分割数组并排序每个子段
局变_左 = 1
局变_间隔 = 局变_阀值
循环判断首 ()
' 计算右边界并修正(防止越界)
局变_右 = 局变_左 + 局变_间隔 - 1
如果 (局变_右 > 局变_数组个数)
局变_右 = 局变_数组个数



' 确保左边界≤右边界(避免无效排序)
如果 (局变_左 > 局变_右)
跳出循环 ()



' 排序当前子段
子程序_二分插入排序3 (参数_数组, 局变_左, 局变_右)
' 移动到下一个子段
局变_左 = 局变_右 + 1
' 所有子段处理完毕,退出循环
如果 (局变_左 > 局变_数组个数)
跳出循环 ()



循环判断尾 ()
' 第二阶段:归并排序(逐步合并子数组)
局变_间隔 = 局变_阀值
循环判断首 ()
局变_游标x首 = 1  ' 每次从数组头部开始归并
' 归并当前间隔下的所有相邻子数组
循环判断首 ()
' 计算左子数组边界并修正
局变_游标x尾 = 局变_游标x首 + 局变_间隔 - 1
如果 (局变_游标x尾 > 局变_数组个数)
局变_游标x尾 = 局变_数组个数



' 计算右子数组起始位置
局变_游标y首 = 局变_游标x尾 + 1
' 右子数组不存在(已到数组末尾),退出当前间隔的归并
如果 (局变_游标y首 > 局变_数组个数)
跳出循环 ()



' 计算右子数组边界并修正
局变_游标y尾 = 局变_游标y首 + 局变_间隔 - 1
如果 (局变_游标y尾 > 局变_数组个数)
局变_游标y尾 = 局变_数组个数



' 归并两个相邻子数组
子程序_归并排序_正常 (参数_数组, 局变_游标x首, 局变_游标x尾, 局变_游标y首, 局变_游标y尾)
' 移动到下一组子数组
局变_游标x首 = 局变_游标y尾 + 1
' 所有组处理完毕,退出当前间隔的归并
如果 (局变_游标x首 > 局变_数组个数)
跳出循环 ()



循环判断尾 ()
' 间隔翻倍(归并更大的子数组)
局变_间隔 = 局变_间隔 × 2
' 间隔超过数组长度,排序完成
如果 (局变_间隔 > 局变_数组个数)
跳出循环 ()



循环判断尾 ()
子程序名返回值类型公开备 注
子程序_二分插入排序3  
参数名类 型参考可空数组备 注
参数_数组整数型
参数_左整数型
参数_右整数型
变量名类 型静态数组备 注
n1整数型 
局变_临时整数型 
局变_左整数型 
局变_右整数型 
局变_中间整数型 
m1整数型 
' 边界检查:无需排序的情况
如果 (参数_左 ≥ 参数_右)
返回 ()



' 从第二个元素开始插入排序
变量循环首 (参数_左 + 1, 参数_右, 1, n1)
局变_临时 = 参数_数组 [n1]  ' 保存当前插入值
局变_左 = 参数_左  ' 二分查找左边界
局变_右 = n1 - 1  ' 二分查找右边界
' 二分查找插入位置
判断循环首 (局变_左 ≤ 局变_右)
局变_中间 = 局变_左 (局变_右 - 局变_左) ÷ 2  ' 避免溢出
如果 (参数_数组 [局变_中间] > 局变_临时)
局变_右 = 局变_中间 - 1  ' 目标在左半部分
局变_左 = 局变_中间 + 1  ' 目标在右半部分

判断循环尾 ()
' 元素后移(从插入位置到当前位置)
变量循环首 (n1 - 1, 局变_左, -1, m1)
参数_数组 [m1 + 1] = 参数_数组 [m1]
变量循环尾 ()
' 插入元素
参数_数组 [局变_左] = 局变_临时
变量循环尾 ()
子程序名返回值类型公开备 注
子程序_归并排序_正常  
参数名类 型参考可空数组备 注
参数_数组整数型
参数_游标x首整数型
参数_游标x尾整数型
参数_游标y首整数型
参数_游标y尾整数型
变量名类 型静态数组备 注
局变_i整数型' 左子数组游标
局变_j整数型 ' 右子数组游标
局变_k整数型' 结果数组游标
' 边界检查:无效参数直接返回
如果 (参数_游标x首 > 参数_游标x尾 参数_游标y首 > 参数_游标y尾)
返回 ()



' 将待归并的元素复制到临时数组
变量循环首 (参数_游标x首, 参数_游标y尾, 1, 局变_i)
程变_临时 [局变_i] = 参数_数组 [局变_i]
变量循环尾 ()
' 初始化游标
局变_i = 参数_游标x首
局变_j = 参数_游标y首
局变_k = 参数_游标x首
' 归并两个有序子数组
循环判断首 ()
' 左子数组已处理完,复制右子数组剩余元素
如果 (局变_i > 参数_游标x尾)
变量循环首 (局变_j, 参数_游标y尾, 1, 局变_j)
参数_数组 [局变_k] = 程变_临时 [局变_j]
局变_k = 局变_k + 1
变量循环尾 ()
跳出循环 ()



' 右子数组已处理完,复制左子数组剩余元素
如果 (局变_j > 参数_游标y尾)
变量循环首 (局变_i, 参数_游标x尾, 1, 局变_i)
参数_数组 [局变_k] = 程变_临时 [局变_i]
局变_k = 局变_k + 1
变量循环尾 ()
跳出循环 ()



' 比较并取较小元素
如果 (程变_临时 [局变_i] ≤ 程变_临时 [局变_j])
参数_数组 [局变_k] = 程变_临时 [局变_i]
局变_i = 局变_i + 1
参数_数组 [局变_k] = 程变_临时 [局变_j]
局变_j = 局变_j + 1
局变_k = 局变_k + 1
循环判断尾 ()


i支持库列表   支持库注释   
spec特殊功能支持库



新建文件夹 2.zip

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


结帖率:0% (0/1)

签到天数: 13 天

发表于 半小时前 | 显示全部楼层   江苏省徐州市
6666666666666666
回复 支持 反对

使用道具 举报

结帖率:0% (0/2)

签到天数: 13 天

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

使用道具 举报

签到天数: 9 天

发表于 2 小时前 | 显示全部楼层   广东省惠州市
坚持学习,支持论坛
回复 支持 反对

使用道具 举报

结帖率:80% (59/74)

签到天数: 11 天

发表于 4 小时前 | 显示全部楼层   广东省珠海市
回复 支持 反对

使用道具 举报

结帖率:100% (3/3)

签到天数: 14 天

发表于 5 小时前 | 显示全部楼层   贵州省毕节市
功德无量
回复 支持 反对

使用道具 举报

结帖率:100% (3/3)

签到天数: 6 天

发表于 5 小时前 | 显示全部楼层   广东省深圳市
学习一下
回复 支持 反对

使用道具 举报

结帖率:100% (3/3)

签到天数: 12 天

发表于 7 小时前 | 显示全部楼层   江苏省苏州市
这非常有趣
回复 支持 反对

使用道具 举报

结帖率:50% (1/2)

签到天数: 12 天

发表于 7 小时前 | 显示全部楼层   广东省汕头市
感谢大神分享~!
回复 支持 反对

使用道具 举报

签到天数: 9 天

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

使用道具 举报

结帖率:80% (4/5)

签到天数: 3 天

发表于 9 小时前 | 显示全部楼层   山东省潍坊市
已经顶贴,感谢您对论坛的支持!
回复 支持 反对

使用道具 举报

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

本版积分规则 致发广告者

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

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

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