用上面这六组数字, 求出 6 个数字

第一大组:
(1)03,06,07,08,09,10,12,14,19,20,24,25,28,30,32,33
(2)01,02,04,05,11,13,15,16,17,18,21,22,23,26,27,29,31
第二大组:
(3)01,03,04,07,08,09,11,12,15,19,20,21,22,24,26,28,29,30
(4)02,05,06,10,13,14,16,17,18,23,25,27,31,32,33
第三大组:
(5)01,03,04,05,06,07,08,09,11,12,17,18,22,23,25,27,28,30,31,33
(6)02,10,13,14,15,16,19,20,21,24,26,29
用上面这六组数字, 求出 6 个数字.使其满足如下条件:
A: 6个数字中, 上面这六组数字,每组都包含有 3 个. 如果不能包含3个的,尽量使其包含2个

 

解决方案:

1.先合并这六组数据,进行排序暂时保存于新数组temp[]中

2.循环去出temp[]中的数据去和上面6组中的数据匹配,记录匹配的组号于Map<int,List<int>>中

3.遍历Map,任意找出6个数字,查看其List,如果它们相对应的组号最少出现两次,OK,成功,否则,继续寻找,知道匹配成功。

4. 6个数据的选择方案:可以按顺序先选择6个匹配,不行则先去尾,向后查找直到结束。没有匹配则再去头,向后查找直到结束。

 

注:

结果一:1,2,3,4,5,10

这只是我想到的一种方案,如果大家还有好多想法希望不吝回复!呵呵

 

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值