12个球称3找出次品的问题.docVIP

  1. 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
  2. 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  3. 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
  4. 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
  5. 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们
  6. 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
  7. 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
12个球称3找出次品的问题

?  12个球称3次找出次品的问题 □ 天宇 发表于 2007-7-29 6:57:00 ????????? 题目:有12个球,已知其中有一个球为次品,但是不清楚是轻还是种,现手头有一架天平,要求只能称三次,找出那个次品的球. ???????? 乍看起来,好象没什么难度,仔细一琢磨,还满费了不少事,下面是解决的办法: ??????? ???????? 第一次称: ??????? 1、2、3、4与5、6、7、8,(a、b、c、d先不理) 若两边平衡,则再称两次即可判别(步骤:略),现在讨论不平衡的情况。 若左重,右轻(若左轻右重,解法同理): (此时判定abcd四球是正常的球!)? ?????????第二次称:? ?????????1、2、5与3、6、a。 一:若平衡,则排除12356,而abcd第一次称已经被排除,故只有两种可能性:4就是所找的球而且是比正常球稍重的;或者78两球其中一球是要找的而且是比正常球稍轻的。故再称第三次即可判别! 二:若左重,右轻,即有两种可能性:所找的球为稍重的而且为1与2其中一个,或者6为所找的球而且是稍轻的(因为3是第一次称时左边的,而a是正常的,故可排除!),于是,再称第三次即可判别! 三:若左轻,右重,即有两种可能性:所找的球为5而且是稍轻的(因为第一次称时只有56是右边的);或者所找的球为3而且为稍重的(因为第一次只有123在左边,而a又是正常的),于是,再称第三次即可判别. ???????? 在网络上还找到了一个强人写的程序流程: 现在把12个球随机分成3组: A[a1,a2,a3,a4],B[b1,b2,b3,b4],C[c1,c2,c3,c4] 对A组与B组进行秤重 Case1:Weight(A)=Weight(B) ???????? 说明有问题的球在C组,同时说明A,B组中的球是ok的。 ????????? 现在取C组中的三个球组成D组,与A,B组中取三个正常球组成E组进行比较。 ????????? if Weight(D) = Weight(E) ????????????????{ ??????????????????? 说明D-C(C组剩下的那个球)是异常球,拿一个正常球 ?????????????? ?与它秤一下就知道是轻球还是重球 ??????????????? } ????????? else if Weight(D) Weight(E) ??????????????? { ???????????????????? 说明异常球在D组中且是个重球 ?????????????????????取D组中的两个球进行比较,结果出来了?? ?????????????????} ????????? else if Weight(D) Weight(E) ??????????????? { ???????????????????? 说明异常球在D组中且是个重球 ?????????????????????取D组中的两个球进行比较,结果出来了?? ?????????????????} ????????? else if Weight(D)? Weight(E) ??????????????? { ???????????????????? 说明异常球在D组中且是个轻球 ?????????????????????取D组中的两个球进行比较,结果出来了?? ?????????????????} Case2:Weight(A) Weight(B) ????????? 取B中的两个球+A中的一个球组成D组, ????????? 用D组(3个球)与B组(B中剩下的两个球+一个正常球)进行比较(一定要是与 ????????? B组比,因为它包含了B组中剩下的两个球) ????????? if Weight(D) = Weight(B) ????????? { ??????????????? 说明B,D组中的球都是正常的,同时原来的B组全是正常球 ??????????????? 根据第一次秤Weight(A) Weight(B),说明不正常的的球在 ??????????????? A组剩下来的两个球中而且是重球 ?????????????? 把剩下两个球秤一下,结果出来了 ????????? } ???????? else? if Weight(D)? Weight(B) ???????? { ?????????????? D组:B中两个球+A中一个球 ?????????????? B组:B中两个球+一个正常球 ?????????????? Weight(A) Weight(B) ?????????????? Weight(D)? Weight(B) ??????????????

文档评论(0)

baa89089 + 关注
实名认证
文档贡献者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档