题意:就是给出一个字符串,让你去一个一个猜测,相同字母算一次,如果是之前猜过的也算错,如果你在错7次前猜对就算你赢,文章中是LRJ的例题代码。

  1. #include<stdio.h>
  2. #include<string.h>
  3. #define maxn 100
  4. int left, chance;
  5. char s[maxn], s2[maxn];
  6. int win, lose;
  7. void guess(char ch) {
  8. int bad = 1;
  9. for(int i = 0; i < strlen(s); i++)
  10. if(s[i] == ch) { left--; s[i] = ' '; bad = 0; }
  11. if(bad) --chance;
  12. if(!chance) lose = 1;
  13. if(!left) win = 1;
  14. }
  15. int main() {
  16. int rnd;
  17. while(scanf("%d%s%s", &rnd, s, s2) == 3 && rnd != -1) {
  18. printf("Round %d\n", rnd);
  19. win = lose = 0;
  20. left = strlen(s);
  21. chance = 7;
  22. for(int i = 0; i < strlen(s2); i++) {
  23. guess(s2[i]);
  24. if(win || lose) break;
  25. }
  26. if(win) printf("You win.\n");
  27. else if(lose) printf("You lose.\n");
  28. else printf("You chickened out.\n");
  29. }
  30. return 0;
  31. }
  1. #include<cstdio>
  2. #include<cstring>
  3. #include <iostream>
  4. using namespace std;
  5. int main()
  6. {
  7. int n;
  8. while(scanf("%d",&n)!=EOF && n!=-1)
  9. {
  10. char str1[1005],str2[1005];
  11. int a[27],b[27];
  12. printf("Round %d\n",n);
  13. scanf("%s%s",str1,str2);
  14. int len1=strlen(str1);
  15. int len2=strlen(str2);
  16. memset(a,0,sizeof(a));
  17. memset(b,1,sizeof(b));
  18. int x=0,y=0,z=0,t=0;
  19. for(int i=0;i<len1;++i)
  20. {
  21. a[str1[i]-'a']=1;
  22. }
  23. for(int i=0;i<len1;++i)
  24. {
  25. if(a[str1[i]-'a']==1 && b[str1[i]-'a'])
  26. {
  27. t++;
  28. b[str1[i]-'a']=0;
  29. }
  30. }
  31. for(int i=0;i<len2;++i)
  32. {
  33. if(a[str2[i]-'a']==1)
  34. {
  35. x++;
  36. a[str2[i]-'a']=-1;
  37. }
  38. else if(a[str2[i]-'a']==0)
  39. y++;
  40. else
  41. z++;
  42. if(y>6 || x-z>=t)
  43. break;
  44. }
  45. if(y>6)
  46. printf("You lose.\n");
  47. else if(x-z>=t)
  48. printf("You win.\n");
  49. else
  50. printf("You chickened out.\n");
  51. }
  52. return 0;
  53. }

UVA489 - Hangman Judge【紫书例题4.2】的更多相关文章

  1. 紫书 例题 11-13 UVa 10735(混合图的欧拉回路)(最大流)

    这道题写了两个多小时-- 首先讲一下怎么建模 我们的目的是让所有点的出度等于入度 那么我们可以把点分为两部分, 一部分出度大于入度, 一部分入度大于出度 那么显然, 按照书里的思路,将边方向后,就相当 ...

  2. 紫书 例题8-3 UVa 1152(中途相遇法)

    这道题要逆向思维, 就是求出答案的一部分, 然后反过去去寻找答案存不存在. 其实很多其他题都用了这道题目的方法, 自己以前都没有发现, 这道题专门考这个方法.这个方法可以没有一直往下求, 可以省去很多 ...

  3. 紫书 例题8-12 UVa 12627 (找规律 + 递归)

    紫书上有很明显的笔误, 公式写错了.g(k, i)的那个公式应该加上c(k-1)而不是c(k).如果加上c(k-1)那就是这一次 所有的红气球的数目, 肯定大于最下面i行的红气球数 我用的是f的公式, ...

  4. 紫书 例题8-4 UVa 11134(问题分解 + 贪心)

     这道题目可以把问题分解, 因为x坐标和y坐标的答案之间没有联系, 所以可以单独求两个坐标的答案 我一开始想的是按照左区间从小到大, 相同的时候从右区间从小到大排序, 然后WA 去uDebug找了数据 ...

  5. 紫书 例题8-17 UVa 1609 (构造法)(详细注释)

    这道题用构造法, 就是自己依据题目想出一种可以得到解的方法, 没有什么规律可言, 只能根据题目本身来思考. 这道题的构造法比较复杂, 不知道刘汝佳是怎么想出来的, 我想的话肯定想不到. 具体思路紫书上 ...

  6. 紫书 例题 9-5 UVa 12563 ( 01背包变形)

    总的来说就是价值为1,时间因物品而变,同时注意要刚好取到的01背包 (1)时间方面.按照题意,每首歌的时间最多为t + w - 1,这里要注意. 同时记得最后要加入时间为678的一首歌曲 (2)这里因 ...

  7. UVa 12169 Disgruntled Judge 紫书

    思路还是按照紫书,枚举a,得出b, 然后验证. 代码参考了LRJ的. #include <cstdio> #include <iostream> using namespace ...

  8. 【紫书】uva489 Hangman Judge 做了很久Orz

    题目链接:https://vjudge.net/problem/UVA-489 题意:给出两行字符串,第一行是标准答案,第二行是玩家猜的串.玩家每次猜一个,猜对一个,标准答案中所有该字符都算被猜到.猜 ...

  9. 紫书 例题8-13 UVa 11093 (反证法)

    这道题发现一个性质就解决了 如果以i为起点, 然后一直加油耗油, 到p这个地方要去p+1的时候没油了, 那么i, i+1, --一直到p, 如果以这些点 为起点, 肯定也走不完. 为什么呢? 用反证法 ...

随机推荐

  1. 设计模式-&gt;观察者模式

    观察者模式能很大的降低模块之前的耦合.详细的观察者模式,客官们能够去看<设计模式>或者<Head first设计模式>等之类的书. 在java中,java.util库中封装了观 ...

  2. linux下华为HSPA模块MU609的驱动问题

    环境: CPU: s3c2416 Linux: 3.6 模块: HUAWEI MU609 SIM卡: 移动3G卡.移动4G卡 首先,拿到MU609模块后,第一要做的是对模块进行一些熟悉与了解,那么资料 ...

  3. POJ题目1947 Rebuilding Roads(树形dp)

    Rebuilding Roads Time Limit: 1000MS   Memory Limit: 30000K Total Submissions: 9957   Accepted: 4537 ...

  4. Java 递归、尾递归、非递归、栈 处理 三角数问题

    import java.io.BufferedReader; import java.io.InputStreamReader; //1,3,6,10,15...n 三角数 /* * # 1 * ## ...

  5. [SDOI 2013] 直径

    [题目链接] https://www.lydsy.com/JudgeOnline/problem.php?id=3124 [算法] 树的直径 [代码] #include<bits/stdc++. ...

  6. [DP专题]悬线法

    参考:https://blog.csdn.net/twtsa/article/details/8120269 先给出题目来源:(洛谷) 1.p1387 最大正方形 2.P1169 棋盘制作 3.p27 ...

  7. c语言中struct的初始化

    C++中的struct已经和class一样,可以用构造函数初始化. C语言中的struct怎么初始化呢? typedef struct _TEST_T {        int i;        c ...

  8. Wireshark 、HTTPWatch、Fiddler的介绍

    一.Wireshark  <TCP/IP协议监听> Wireshark(前称Ethereal)是一个网络封包分析软件.网络封包分析软件的功能是撷取网络封包,并尽可能显示出最为详细的网络封包 ...

  9. 基于CGAL的Delaunay三角网应用

    目录 1. 背景 1.1 CGAL 1.2 cgal-bindings(Python包) 1.3 vtk-python 1.4 PyQt5 2. 功能设计 2.1 基本目标 2.2 待实现目标 3. ...

  10. python之路——常用模块

    阅读目录 认识模块 什么是模块 模块的导入和使用 常用模块一 collections模块 时间模块 random模块 os模块 sys模块 序列化模块 re模块 常用模块二 hashlib模块 con ...