免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
最近访问板块 发新帖
楼主: xueskyjian
打印 上一主题 下一主题

[C++] 一副扑克牌被洗过,顺序打乱,被随意抽走一张,请根据剩下的牌,最快找到抽走牌。 [复制链接]

论坛徽章:
1
射手座
日期:2013-08-21 13:11:46
11 [报告]
发表于 2012-08-06 09:25 |只看该作者
空间换时间
搞两个队列,第一个队列打乱,就是你那一副牌,第二个队列最开始是空的
抽走一张,就把这张牌push到第二个队列里面去

论坛徽章:
324
射手座
日期:2013-08-23 12:04:38射手座
日期:2013-08-23 16:18:12未羊
日期:2013-08-30 14:33:15水瓶座
日期:2013-09-02 16:44:31摩羯座
日期:2013-09-25 09:33:52双子座
日期:2013-09-26 12:21:10金牛座
日期:2013-10-14 09:08:49申猴
日期:2013-10-16 13:09:43子鼠
日期:2013-10-17 23:23:19射手座
日期:2013-10-18 13:00:27金牛座
日期:2013-10-18 15:47:57午马
日期:2013-10-18 21:43:38
12 [报告]
发表于 2012-08-06 09:39 |只看该作者
遍历   异或

论坛徽章:
44
15-16赛季CBA联赛之浙江
日期:2021-10-11 02:03:59程序设计版块每日发帖之星
日期:2016-07-02 06:20:0015-16赛季CBA联赛之新疆
日期:2016-04-25 10:55:452016科比退役纪念章
日期:2016-04-23 00:51:2315-16赛季CBA联赛之山东
日期:2016-04-17 12:00:2815-16赛季CBA联赛之福建
日期:2016-04-12 15:21:2915-16赛季CBA联赛之辽宁
日期:2016-03-24 21:38:2715-16赛季CBA联赛之福建
日期:2016-03-18 12:13:4015-16赛季CBA联赛之佛山
日期:2016-02-05 00:55:2015-16赛季CBA联赛之佛山
日期:2016-02-04 21:11:3615-16赛季CBA联赛之天津
日期:2016-11-02 00:33:1215-16赛季CBA联赛之浙江
日期:2017-01-13 01:31:49
13 [报告]
发表于 2012-08-06 09:49 |只看该作者
就算遍历一遍你也只能“知道”哪一张牌被抽走,但是没办法“找到”那张牌,鬼知道抽牌的人把那张牌放到那儿了。
换句话说你也用不着在剩下的牌堆里下功夫,抓住那个抽牌的人痛打他一顿即可。

论坛徽章:
0
14 [报告]
发表于 2012-08-06 10:31 |只看该作者
回复 13# windoze
哈哈,你真幽默,知道是哪张牌被抽走了,就算找到了~~~

   

论坛徽章:
0
15 [报告]
发表于 2012-08-06 10:48 |只看该作者
我有个想法,首先确定被抽走的牌是哪个色。<红桃><方块><黑桃><梅花>,每个颜色的牌有13张,1,2,3,4,5,6,7,8,9,10,t,p,k.
方法一:剩下的51张(大小王不在)加起来求和,与52张牌的和比较,两者之差就是被抽走牌的大小。然后再确定颜色。
方法二:首先计算出1到k的和,让后分色并相加,与首先计算的和比较,相差为0的,此色牌完整,否则相差值即为所在色的牌

论坛徽章:
44
15-16赛季CBA联赛之浙江
日期:2021-10-11 02:03:59程序设计版块每日发帖之星
日期:2016-07-02 06:20:0015-16赛季CBA联赛之新疆
日期:2016-04-25 10:55:452016科比退役纪念章
日期:2016-04-23 00:51:2315-16赛季CBA联赛之山东
日期:2016-04-17 12:00:2815-16赛季CBA联赛之福建
日期:2016-04-12 15:21:2915-16赛季CBA联赛之辽宁
日期:2016-03-24 21:38:2715-16赛季CBA联赛之福建
日期:2016-03-18 12:13:4015-16赛季CBA联赛之佛山
日期:2016-02-05 00:55:2015-16赛季CBA联赛之佛山
日期:2016-02-04 21:11:3615-16赛季CBA联赛之天津
日期:2016-11-02 00:33:1215-16赛季CBA联赛之浙江
日期:2017-01-13 01:31:49
16 [报告]
发表于 2012-08-06 11:33 |只看该作者
xueskyjian 发表于 2012-08-04 18:21
有没有一种算法,可以最大概率,最快的算出被别人抽走的牌,谢谢


穷举剩下的牌,因为一副牌中所有牌是确定的,所以算出被人抽走的牌概率为1;因为一副牌只有52张(不算大小王),所以不管怎么穷举,时间复杂度都为O(1)。
从算法角度来说这就是最快最好的。

论坛徽章:
1
2015年辞旧岁徽章
日期:2015-03-03 16:54:15
17 [报告]
发表于 2012-08-06 12:45 |只看该作者
抽的时候打日志就可以了。

论坛徽章:
7
荣誉版主
日期:2011-11-23 16:44:17子鼠
日期:2014-07-24 15:38:07狮子座
日期:2014-07-24 11:00:54巨蟹座
日期:2014-07-21 19:03:10双子座
日期:2014-05-22 12:00:09卯兔
日期:2014-05-08 19:43:17卯兔
日期:2014-08-22 13:39:09
18 [报告]
发表于 2012-08-06 13:25 |只看该作者
随便猜一张,有1/52几率

论坛徽章:
0
19 [报告]
发表于 2012-08-06 13:56 |只看该作者
顶!!!!!!!!!!

论坛徽章:
0
20 [报告]
发表于 2012-08-06 17:15 |只看该作者
flw 发表于 2012-08-06 12:45
抽的时候打日志就可以了。

顶,这个狠!
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

北京盛拓优讯信息技术有限公司. 版权所有 京ICP备16024965号-6 北京市公安局海淀分局网监中心备案编号:11010802020122 niuxiaotong@pcpop.com 17352615567
未成年举报专区
中国互联网协会会员  联系我们:huangweiwei@itpub.net
感谢所有关心和支持过ChinaUnix的朋友们 转载本站内容请注明原作者名及出处

清除 Cookies - ChinaUnix - Archiver - WAP - TOP