12
返回列表 发新帖
楼主: roseway
跳转到指定楼层
上一主题 下一主题
收起左侧

狗家店面

🔗
 楼主| roseway 2019-10-14 12:45:19 | 只看该作者
全局:
LZY20170708 发表于 2019-10-14 12:27
楼主后一个问的意思
“一共选m次,每次选n个元素出来组成一个set. 一共m个set, 并且保证这个m个set共n*m ...

是m个set不能完全一样,比如(1,2,3,4,5)和(1,2,3,4,6)是不一样的
回复

使用道具 举报

🔗
lbjforever 2019-10-15 19:02:31 | 只看该作者
全局:
楼主可以大概讲一下思路嘛 还有保证m次的结果不重复 是怎么想的
已加米
回复

使用道具 举报

🔗
Neal 2019-10-15 23:45:22 | 只看该作者
全局:
请问楼主 随机选择这个条件是必须的吗? 否则就可以 for loop 这组数。这个问题就可以转换成组合问题,就是从 s 个数中选出n个数的组合,因为要选m次,相当于求出m个这种组合,然后每个组合内的数不完全相同
可以用 for loop s, 考虑当前数加入set,再做dfs, 然后backtracking, 当前数不加入set, 然后再做 dfs已给楼主加大米,请教思路,谢谢!
回复

使用道具 举报

🔗
 楼主| roseway 2019-10-16 08:57:24 | 只看该作者
全局:
Neal 发表于 2019-10-15 23:45
请问楼主 随机选择这个条件是必须的吗? 否则就可以 for loop 这组数。这个问题就可以转换成组合问题,就是 ...

必须随机选择。
随机选择的思路就是生成一个介于0到数组长度的randint,取该randint位置的数字作为第一个数字,把该数字和最后一个数字交换;然后生成0到数组长度减一的randint,依此类推。
求m个组合,我当时只回答了选出来的数存起来,每次生成都检查一下,如果重复了重来。这种方法效率很低。
回复

使用道具 举报

🔗
lifuyao 2019-10-16 14:57:17 | 只看该作者
全局:
roseway 发表于 2019-10-16 08:57
必须随机选择。
随机选择的思路就是生成一个介于0到数组长度的randint,取该randint位置的数字作为第一 ...

楼主你好,我觉得可以不可以用洗牌算法处理了之后,其实就是你说的方法(蠡口三巴斯), 然后每一个index开始,都可以作为一个结果,如果还不够,就再洗牌一次,中间还是需要set的
回复

使用道具 举报

您需要登录后才可以回帖 登录 | 注册账号
隐私提醒:
  • ☑ 禁止发布广告,拉群,贴个人联系方式:找人请去🔗同学同事飞友,拉群请去🔗拉群结伴,广告请去🔗跳蚤市场,和 🔗租房广告|找室友
  • ☑ 论坛内容在发帖 30 分钟内可以编辑,过后则不能删帖。为防止被骚扰甚至人肉,不要公开留微信等联系方式,如有需求请以论坛私信方式发送。
  • ☑ 干货版块可免费使用 🔗超级匿名:面经(美国面经、中国面经、数科面经、PM面经),抖包袱(美国、中国)和录取汇报、定位选校版
  • ☑ 查阅全站 🔗各种匿名方法

本版积分规则

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