UVa340 Master-Mind Hints

举报
小哈里 发表于 2022/05/11 01:46:28 2022/05/11
【摘要】 //UVa340 Master-Mind Hints#include<stdio.h>#define max 105 int main(){ //freopen("date.in","r",stdin); int n, a[max], b[max]; int kase = 0; while(scanf("%d",&n...

  
  1. //UVa340 Master-Mind Hints
  2. #include<stdio.h>
  3. #define max 105
  4. int main(){
  5. //freopen("date.in","r",stdin);
  6. int n, a[max], b[max];
  7. int kase = 0;
  8. while(scanf("%d",&n) == 1 && n){ //n=0 时结束循环
  9. printf("Game%d:\n",++kase);
  10. //答案序列
  11. for(int i = 0; i < n; i++)
  12. scanf("%d",&a[i]);
  13. //猜测序列
  14. while(1){
  15. int A = 0, B = 0;
  16. //获取并计算A
  17. for(int i = 0; i<n; i++){
  18. scanf("%d",&b[i]);
  19. if(a[i]==b[i]) A++;
  20. }
  21. //内循环出口条件,游戏切换
  22. if(b[0] == 0) break;
  23. //计算A+B的值
  24. for(int d = 1; d <= 9; d++){
  25. int c1 = 0, c2 = 0;
  26. for(int i = 0; i < n; i++){
  27. if(a[i] == d) c1++;
  28. if(b[i] == d) c2++;
  29. }
  30. if(c1 < c2) B += c1;else B += c2;
  31. }
  32. printf(" (%d,%d)\n", A, B-A);
  33. //continue 下一场游戏,下一个猜测序列
  34. }
  35. //新的游戏
  36. }
  37. return 0;
  38. }
  39. /*
  40. DATE IN:
  41. 4
  42. 1 3 5 5
  43. 1 1 2 3
  44. 4 3 3 5
  45. 6 5 5 1
  46. 6 1 3 5
  47. 1 3 5 5
  48. 0 0 0 0
  49. 10
  50. 1 2 2 2 4 5 6 6 6 9
  51. 1 2 3 4 5 6 7 8 9 1
  52. 1 1 2 2 3 3 4 4 5 5
  53. 1 2 1 3 1 5 1 6 1 9
  54. 1 2 2 5 5 5 6 6 6 7
  55. 0 0 0 0 0 0 0 0 0 0
  56. 0
  57. -------------------
  58. DATE OUT:
  59. Game1:
  60. (1,1)
  61. (2,0)
  62. (1,2)
  63. (1,2)
  64. (4,0)
  65. Game2:
  66. (2,4)
  67. (3,2)
  68. (5,0)
  69. (7,0)
  70. */

文章来源: gwj1314.blog.csdn.net,作者:小哈里,版权归原作者所有,如需转载,请联系作者。

原文链接:gwj1314.blog.csdn.net/article/details/54846331

【版权声明】本文为华为云社区用户转载文章,如果您发现本社区中有涉嫌抄袭的内容,欢迎发送邮件进行举报,并提供相关证据,一经查实,本社区将立刻删除涉嫌侵权内容,举报邮箱: cloudbbs@huaweicloud.com
  • 点赞
  • 收藏
  • 关注作者

评论(0

0/1000
抱歉,系统识别当前为高风险访问,暂不支持该操作

全部回复

上滑加载中

设置昵称

在此一键设置昵称,即可参与社区互动!

*长度不超过10个汉字或20个英文字符,设置后3个月内不可修改。

*长度不超过10个汉字或20个英文字符,设置后3个月内不可修改。