FZU1575小学生的游戏([NWPU]萌新寒假第一次比赛——小学生专场A题)
2018-01-19 19:51
197 查看
题目
某天,无聊的小斌叫上几个同学玩游戏,其中有比较笨的小兴,比较傻的小雪,可爱的小霞和自以为是的小楠。他们去找聪明的小明去给他们当裁判。判定谁取得游戏胜利。
而这个游戏是由小斌想个1到10000000的数字让大家猜,看谁先猜中。为了防止小斌作弊,小明记录下了游戏的整个过程。你的任务是判断小斌是否有作弊。
Input
输入数据包括多盘游戏。一次猜数包含两行,第一行是一个数字n(1<=n<=10000000),表示所猜数字。第二行是小斌的回答为”too high”,”too low”,”right on”三种答案之一。每盘游戏结束于”right on”。当n=0的时候,整个游戏结束。
Output
对于每盘游戏,若小斌确有撒谎,请输出一行”The guy is dishonest”,否则请输出”The guy may be honest”。
Sample Input
10
too high
3
too low
4
too high
2
right on
5
too low
7
too high
6
right on
0
Sample Output
The guy is dishonest
The guy may be honest
解题思路:
所有状态为too high的数决定了小斌心中猜的数的上限,上限应该越小越精确,所以用max记录上限,每次遇到更小的上限则替换。
同理,状态为too low的数决定了小斌心中猜的数的下限,下限应该越大越精确,所以用min记录下限,每次遇到更大的下限则替换。
如果小斌没撒谎,那状态为right on的数应该在小于上限且大于下限。否则,小斌撒谎了。
注意:
每次读入一个数字和一个字符串,并对其进行处理。这样可以节省存储空间。
因为输入的每个数字后面都有一个换行符,所以需要一个getchar读入换行符,否则gets函数会只读入一个换行符。gets函数会读到换行符停止,并把换行符替换成空字符。如果没有getchar,gets读入的是一个由空字符组成的字符串。
每个right on后,一盘游戏结束,需要把min和max重新初始化。
status字符串需要初始化,否则会是乱码。
某天,无聊的小斌叫上几个同学玩游戏,其中有比较笨的小兴,比较傻的小雪,可爱的小霞和自以为是的小楠。他们去找聪明的小明去给他们当裁判。判定谁取得游戏胜利。
而这个游戏是由小斌想个1到10000000的数字让大家猜,看谁先猜中。为了防止小斌作弊,小明记录下了游戏的整个过程。你的任务是判断小斌是否有作弊。
Input
输入数据包括多盘游戏。一次猜数包含两行,第一行是一个数字n(1<=n<=10000000),表示所猜数字。第二行是小斌的回答为”too high”,”too low”,”right on”三种答案之一。每盘游戏结束于”right on”。当n=0的时候,整个游戏结束。
Output
对于每盘游戏,若小斌确有撒谎,请输出一行”The guy is dishonest”,否则请输出”The guy may be honest”。
Sample Input
10
too high
3
too low
4
too high
2
right on
5
too low
7
too high
6
right on
0
Sample Output
The guy is dishonest
The guy may be honest
解题思路:
所有状态为too high的数决定了小斌心中猜的数的上限,上限应该越小越精确,所以用max记录上限,每次遇到更小的上限则替换。
同理,状态为too low的数决定了小斌心中猜的数的下限,下限应该越大越精确,所以用min记录下限,每次遇到更大的下限则替换。
如果小斌没撒谎,那状态为right on的数应该在小于上限且大于下限。否则,小斌撒谎了。
注意:
每次读入一个数字和一个字符串,并对其进行处理。这样可以节省存储空间。
因为输入的每个数字后面都有一个换行符,所以需要一个getchar读入换行符,否则gets函数会只读入一个换行符。gets函数会读到换行符停止,并把换行符替换成空字符。如果没有getchar,gets读入的是一个由空字符组成的字符串。
每个right on后,一盘游戏结束,需要把min和max重新初始化。
status字符串需要初始化,否则会是乱码。
#include<stdio.h> #include<string.h> char less[]={"too high"}; char large[]={"too low"}; char equal[]={"right on"}; int main() { int guess; char temp; char status[10]={0}; int min=0,max=10000000; while(1) { scanf("%d",&guess); if(guess==0) { return 0; } temp=getchar(); gets(status); if(strcmp(status,less)==0) { guess<max?max=guess:max=max; } else if(strcmp(status,large)==0) { guess>min?min=guess:min=min; } else if(strcmp(status,equal)==0) { if(guess<max&&guess>min) { printf("The guy may be honest\n"); } else { printf("The guy is dishonest\n"); } min=0; max=10000000; } } }
相关文章推荐
- 小学生的游戏 FZU - 1575
- FZU 1575 小学生的游戏
- FZU 1575 小学生的游戏(水题)
- FZU 1962 新击鼓传花游戏
- 牛客网NowCoder-2018年全国多校算法寒假训练营练习比赛(第一场) A-大吉大利,今晚吃鸡——枪械篇 F-大吉大利,今晚吃鸡——跑毒篇 H-方块与收纳盒 I-找数字个数
- stl的map2------[NWPU][2018寒假作业][通用版]二、stl ,模拟,贪心等 [Cloned]B题
- //搞不清楚for循环真的害死人//贪心FatMouse's Trade------[NWPU][2018寒假作业][通用版]二E题
- 2018年全国多校算法寒假训练营练习比赛(第二场) B TaoTao要吃鸡【01背包 + 贪心】
- 2018年全国多校算法寒假训练营练习比赛(第二场)D YB要打炉石
- 2018年全国多校算法寒假训练营练习比赛(第二场)
- 2018年全国多校算法寒假训练营练习比赛(第二场)D炉石
- 2018年全国多校算法寒假训练营练习比赛(第二场) A 吐泡泡(模拟)
- 2018年全国多校算法寒假训练营练习比赛(第二场) F 德玛西亚万岁(状态压缩DP 未解决)
- 2018年全国多校算法寒假训练营练习比赛(第二场)解题报告
- 2018年全国多校算法寒假训练营练习比赛(第三场)---A---题(斯特灵公式)
- [游戏]L4D求生之路官方比赛地图修补完善说明
- 寒假比赛第二场b多米诺
- 牛客-2018年全国多校算法寒假训练营练习比赛(第四场)
- 2018年全国多校算法寒假训练营练习比赛(第四场)
- 2018年全国多校算法寒假训练营练习比赛(第四场)-E-通知小弟(强连通缩点)