POJ 1013 假币问题(水题)

雨点打透心脏的1/2处 2024-04-17 05:30 164阅读 0赞

大致题意:

有一打(12枚)硬币,其中有且仅有1枚假币,11枚真币

用A~L作为各个硬币的代号

假币可能比真币略轻,也可能略重

现在利用天枰,根据Input输入的3次称量,找出假币,并输出假币是轻还是重。

解题思路:暴力枚举:枚举每个硬币为轻的假币、重的假币,如果不满足3个称量结果,继续寻找,直到找到满足的。

  1. #include<iostream>
  2. #include<algorithm>
  3. #include<cstdio>
  4. #include<cstring>
  5. using namespace std;
  6. char Left[5][10],Right[5][10],balance[5][10];
  7. bool is_right(char ch,char weight,int k)
  8. {
  9. if(balance[k][0]=='e')
  10. { //判断左边 和右边
  11. if(strchr(Left[k],ch) == NULL&&strchr(Right[k],ch)== NULL)
  12. return true;
  13. else
  14. return false;
  15. }
  16. else if(balance[k][0]=='u')
  17. {
  18. if(weight=='L')
  19. {
  20. if(strchr(Right[k],ch)==NULL)
  21. return false;
  22. else
  23. return true;
  24. }
  25. else if(weight=='H')
  26. {
  27. if(strchr(Left[k],ch)==NULL)
  28. return false;
  29. else
  30. return true;
  31. }
  32. }
  33. else if(balance[k][0]=='d')
  34. {
  35. if(weight=='H')
  36. {
  37. if(strchr(Right[k],ch)==NULL)
  38. return false;
  39. else
  40. return true;
  41. }
  42. else if(weight=='L')
  43. {
  44. if(strchr(Left[k],ch)==NULL)
  45. return false;
  46. else
  47. return true;
  48. }
  49. }
  50. }
  51. int main()
  52. {
  53. int n;
  54. cin>>n;
  55. while(n--)
  56. {
  57. memset(Left,0,sizeof(Left));
  58. memset(Right,0,sizeof(Right));
  59. memset(balance,0,sizeof(balance));
  60. for(int i=1;i<=3;i++)
  61. cin>>Left[i]>>Right[i]>>balance[i];
  62. for(int i=0;i<12;i++)
  63. {
  64. //假设轻
  65. int flag=1;
  66. for(int j=1;j<=3;j++)
  67. {
  68. if(!is_right(i+65,'L',j))
  69. {
  70. flag=0;
  71. break;
  72. }
  73. }
  74. if(flag)
  75. {
  76. printf("%c is the counterfeit coin and it is light.\n",i+65);
  77. break;
  78. }
  79. //假设重
  80. flag=1;
  81. for(int j=1;j<=3;j++)
  82. {
  83. if(!is_right(i+65,'H',j))
  84. {
  85. flag=0;
  86. break;
  87. }
  88. }
  89. if(flag)
  90. {
  91. printf("%c is the counterfeit coin and it is heavy.\n",i+65);
  92. break;
  93. }
  94. }
  95. }
  96. }

发表评论

表情:
评论列表 (有 0 条评论,164人围观)

还没有评论,来说两句吧...

相关阅读

    相关 假币问题(枚举)

    2692:假币问题 描述 赛利有12枚银币。其中有11枚真币和1枚假币。假币看起来和真币没有区别,但是重量不同。但赛利不知道假币比真币轻还是重。于是他向朋友借了一架天平