开启辅助访问 切换到宽版

精易论坛

 找回密码
 注册

QQ登录

只需一步,快速开始

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

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


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

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

查看: 223|回复: 6
收起左侧

[已解决] 遍历所有组合

 关闭 [复制链接]
结帖率:100% (46/46)
发表于 3 天前 | 显示全部楼层 |阅读模式   广东省惠州市
200精币
假设数组里面有20个成员,分别是1-20

十个成员为一个组合,如何遍历所有组合

一个组合内不能重复出现同一个成员,例如:1,2,2,3,4

最佳答案

查看完整内容

https://bbs.ijingyi.com/forum.php?mod=viewthread&tid=14242240 N选M的问题

点评

论坛里面直接搜 M选N   贵州省毕节市  发表于 3 天前

回答提醒:如果本帖被关闭无法回复,您有更好的答案帮助楼主解决,请发表至 源码区 可获得加分喔。
友情提醒:本版被采纳的主题可在 申请荣誉值 页面申请荣誉值,获得 1点 荣誉值,荣誉值可兑换荣誉会员、终身vip用户组。
快捷通道:申请荣誉值

签到天数: 29 天

发表于 3 天前 | 显示全部楼层   广东省广州市

评分

参与人数 1荣誉 +1 收起 理由
笨潴 + 1 热心帮助他人,荣誉+1,希望继续努力(*^__^*) 嘻嘻!

查看全部评分

回复

使用道具 举报

结帖率:100% (1/1)
发表于 3 天前 | 显示全部楼层   浙江省温州市
  
窗口程序集名保 留  保 留备 注
窗口程序集_启动窗口   
子程序名返回值类型公开备 注
递归生成组合  
参数名类 型参考可空数组备 注
起始位置整数型
当前深度整数型
当前组合整数型
成员数组整数型
计数整数型
结果快速文本对象
变量名类 型静态数组备 注
整数型 
文本文本型 
整数型 
如果真 (当前深度 > 10)
计数 = 计数 + 1
文本 = “”
计次循环首 (取数组成员数 (当前组合), 数)
文本 = 文本 + 到文本 (当前组合 [])“ ”
计次循环尾 ()
结果.添加 (文本 + #换行符 )
返回 ()
变量循环首 (起始位置, 20, 1, 数)
当前组合 [当前深度] = 成员数组 []
递归生成组合 (数 + 1, 当前深度 + 1, 当前组合, 成员数组, 计数, 结果)
变量循环尾 ()
子程序名返回值类型公开备 注
__启动窗口_创建完毕  
变量名类 型静态数组备 注
结果快速文本对象 
成员数组整数型20
整数型 
当前组合整数型10
数组文本型0
计次循环首 (20, 数)
成员数组 [] = 数
计次循环尾 ()
结果.清除文本 ()
结果.置内存增量 (10 × 1024 × 1024)
递归生成组合 (1, 1, 当前组合, 成员数组, 0, 结果)
数组 = 分割文本 (结果.取文本 (, ), #换行符, )
调试输出 (取数组成员数 (数组))


i支持库列表   支持库注释   
commobj通用对象支持库
spec特殊功能支持库

开始运行被调试程序
* 184756
被调试易程序运行完毕
回复

使用道具 举报

结帖率:33% (1/3)

签到天数: 19 天

发表于 3 天前 | 显示全部楼层   广东省深圳市
位置不同的组合算不算?比如abcd,bcda,这样算2组,还是算一组?
回复

使用道具 举报

结帖率:88% (49/56)

签到天数: 28 天

发表于 3 天前 | 显示全部楼层   四川省成都市
  
窗口程序集名保 留  保 留备 注
窗口程序集_启动窗口   
变量名类 型数组备 注
数组整数型0 
当前组合整数型0 
组合计数整数型  

子程序名返回值类型公开备 注
__启动窗口_创建完毕  

子程序名返回值类型公开备 注
_按钮_生成组合_被单击  
变量名类 型静态数组备 注
i整数型 
重定义数组 (数组, 假, 20)
' 初始化数组为1-20
计次循环首 (20, i)
数组 [i] = i
计次循环尾 ()
组合计数 = 0
重定义数组 (当前组合, 假, 10)
编辑框1.内容 = ""
生成组合优化版 (1, 1)
编辑框1.内容 = "共生成 " + 到文本 (组合计数) + " 个组合" + #换行符 + 编辑框1.内容
子程序名返回值类型公开备 注
生成组合优化版  
参数名类 型参考可空数组备 注
当前位置整数型
深度整数型
变量名类 型静态数组备 注
i整数型 
组合文本文本型 
如果真 (深度 > 10)
组合计数 = 组合计数 + 1

' 构建组合文本
组合文本 = ""
计次循环首 (10, i)
如果 (i = 1)
组合文本 = 到文本 (当前组合 [i])
组合文本 = 组合文本 + "," + 到文本 (当前组合 [i])

计次循环尾 ()

' 只显示前20个组合
如果真 (组合计数 ≤ 20)
编辑框1.加入文本 ("组合" + 到文本 (组合计数) + ": " + 组合文本 + #换行符 )

返回 ()

计次循环首 (20 - 当前位置 + 1, i)
如果真 (10 - 深度 + 1 > 20 - 当前位置 - i + 2)
返回 ()  ' 剩余元素不足以形成组合

当前组合 [深度] = 数组 [当前位置 + i - 1]
生成组合优化版 (当前位置 + i, 深度 + 1)
计次循环尾 ()
回复

使用道具 举报

结帖率:100% (26/26)

签到天数: 24 天

发表于 3 天前 | 显示全部楼层   河南省新乡市
论坛有现成的,如果有帮助请采纳
[深度优先]数的组合排列全排列和N选M排列
https://bbs.ijingyi.com/forum.php?mod=viewthread&tid=14242240
(出处: 精易论坛)
回复

使用道具 举报

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

本版积分规则 致发广告者

关闭

精易论坛 - 有你更精彩上一条 /2 下一条

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

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

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