例题 4-2 刽子手游戏(Hangman Judge)
来源:互联网 发布:sql 删除表中的行 编辑:程序博客网 时间:2024/06/08 01:38
Hangman Judge是一个猜英文单字的小游戏(在电子字典中常会看到),游戏规则如下:
1、答案单字写在纸上(每个字元一张纸),并且被盖起来,玩家每次猜一个英文字元(letter)。
2、如果这个英文字元猜中(在答案的英文单字中有出现),被猜中的字元就被翻开。例如:答案是book,如果你猜o,book中的两个o就会被视为已猜中。
3、如果这个英文字元未出现在答案的单字中,就会在hangman的图中多加一划。要完成hangman图共需7划,如下图。注意:同一个猜错的字元只能再图上画一划,例如:答案是book,第一次你猜a(未猜中)会在图上画一划,但第二次以后再猜a并不会再多画。
4、如果在hangman图完成之前,玩家已猜中所有答案中的字元,则玩家赢(win)。
5、如果玩家尚未猜中所有答案中的字元而hangman图完成了,,则玩家输(lose)。
6、如果玩家在还没输赢的情况之下就不玩了,那我们说玩家胆小放弃了(chicken out)
______ | | | O | /|\ | | | / \ __|_ | |______ |_________|
你的任务就是要写一个程序根据答案及玩家输入的猜测来判断玩家是赢、输、或放弃。
【输入】
会有好几组测试数据,每一组有3列。第一列为一个数字n,代表第几回合,第二列为这一回合的答案,第三列为这一回合玩家输入的猜测。如果n = -1代表输入结束。
Input
1
cheese
chese
2
cheese
abcdefg
3
cheese
abcdefgij
-1
Output
Round 1
You win.
Round 2
You chickened out.
Round 3
You lose.
实现:
#include<stdio.h>#include<string.h>#define maxn 100000int main(){int n;char s[maxn], a[maxn];int lens, lena;int guessed[30]; //初始为0 当其值为1时 代表 这个已经猜对了int i, j;int is_lose, is_win;//freopen("C:\\Users\\zhangwei\\Desktop\\input.txt","r",stdin); //freopen("C:\\Users\\zhangwei\\Desktop\\output.txt","w",stdout); while(scanf("%d",&n) == 1 && n != -1){scanf("%s",s);scanf("%s",a); lens = strlen(s);lena = strlen(a);i = 0;j = 0;is_lose = 0;is_win = 1;memset(guessed, 0, sizeof(guessed));int cnt_false = 0; //统计错误次数while(j < lena){for(i = 0; i < lens; i++ ){if(!guessed[a[j]-'a'] && a[j] == s[i]){//以a[]数组为判断核心guessed[a[j]-'a'] = 1;break;}else if(guessed[a[j]-'a']){cnt_false++;break;}}if(i == lens)//当 猜到末尾仍然没有发现猜对时 就是 猜错了cnt_false++;if(cnt_false >= 7){is_lose = 1;break; }j++;}for(int i = 0; i < lens; i++ ){//判断 答案中的字符是否全部被猜对if(guessed[s[i]-'a'] != 1){is_win = 0;break;}}printf("Round %d\n",n);if(is_win == 0 && is_lose == 0)printf("You chickened out.\n");else if(is_win){printf("You win.\n");}else if(is_lose){printf("You lose.\n");} }return 0;}
阅读全文
0 0
- 例题 4-2 刽子手游戏(Hangman Judge)
- UVa 489 Hangman Judge(刽子手游戏)
- Uva-489 - Hangman Judge(刽子手游戏)
- 刽子手游戏(Hangman judge,Uva489)
- 刽子手游戏(Hangman Judge, UVa 489)
- Hangman Judge 刽子手游戏----(猜单词)
- UVa 489 Hangman Judge 刽子手游戏
- UVa - 489 - Hangman Judge(刽子手游戏)
- Hangman Judge 刽子手游戏UVA 489
- 例题4-2 刽子手游戏
- 例题4-2刽子手游戏
- 例题4-2 uva 489 - Hangman Judge
- 例题4-2 刽子手游戏 UVa489
- 刽子手(Hangman Judge, UVA 489)
- UVA 489 Hangman Judge【刽子手】
- ☆算法竞赛入门经典(第二版) 例题4-2 猜单词(Hangman Judge) UVa489
- 算法竞赛入门经典 刽子手游戏 Rail ,Hangman judge UVa 489
- 例4-2 UVa489 Hangman Judge
- 2017.8.21-----二分!!!在树状数组中的巧妙运用
- 端口占用问题的解决办法
- Lombok 安装、入门
- Java算法之递归算法
- 常用的shell脚本
- 例题 4-2 刽子手游戏(Hangman Judge)
- jdbc的简单使用
- 验证码的产品体验
- 小心stringstream.str()字符串用法的陷阱
- 爬虫问题汇总 + 解决
- 字符集GBK,GB2312,GB18030,UNICODE,UTF-8
- PyQt标准框——QInputDialog(二)
- mysql导数据遇到错误提示ERROR 1227,Acess denied
- twitter的snowflake算法