
【欢迎关注微信公众号:计算机黑科学大全,对话框回复:PAT乙级真题】获取全部真题详解及代码示例
个人博客地址:https://mzwang.top
小赌怡情
题目描述:
常言道“小赌怡情”。这是一个很简单的小游戏:首先由计算机给出第一个整数;然后玩家下注赌第二个整数将会比第一个数大还是小;玩家下注 t 个筹码后,计算机给出第二个数。若玩家猜对了,则系统奖励玩家 t 个筹码;否则扣除玩家 t 个筹码。
注意:玩家下注的筹码数不能超过自己帐户上拥有的筹码数。当玩家输光了全部筹码后,游戏就结束。
输入格式:
输入在第一行给出 2 个正整数 T 和 K(≤ 100),分别是系统在初始状态下赠送给玩家的筹码数、以及需要处理的游戏次数。随后 K 行,每行对应一次游戏,顺序给出 4 个数字:
n1 b t n2其中
n1和n2是计算机先后给出的两个[0, 9]内的整数,保证两个数字不相等。b为 0 表示玩家赌小,为 1 表示玩家赌大。t表示玩家下注的筹码数,保证在整型范围内。输出格式:
对每一次游戏,根据下列情况对应输出(其中
t是玩家下注量,x是玩家当前持有的筹码量):
- 玩家赢,输出
Win t! Total = x.;- 玩家输,输出
Lose t. Total = x.;- 玩家下注超过持有的筹码量,输出
Not enough tokens. Total = x.;- 玩家输光后,输出
Game Over.并结束程序。输入样例1:
100 4 8 0 100 2 3 1 50 1 5 1 200 6 7 0 200 8输出样例1:
Win 100! Total = 200. Lose 50. Total = 150. Not enough tokens. Total = 150. Not enough tokens. Total = 150.输入样例2:
100 4 8 0 100 2 3 1 200 1 5 1 200 6 7 0 200 8输出样例2:
Win 100! Total = 200. Lose 200. Total = 0. Game Over.题目来源:PAT乙级1071
作者:CHEN, Yue
单位:浙江大学
问题解决:
解题思想
此题按照各情况分开进行处理和输出即可,注意各种情况的优先顺序,比如应优先判断玩家下注是否超过持有的筹码量,再判断输赢。
代码示例(C/C++)
#include <cstdio>
using namespace std;
int main() {
int T, K;
scanf("%d%d", &T, &K);
while(K--) {
int n1, n2, b, t;
scanf("%d%d%d%d", &n1, &b, &t, &n2);
if(t > T) { //玩家下注超过持有的筹码量
printf("Not enough tokens. Total = %d.\n", T);
}
else if((b && n1 < n2) || (!b && n1 > n2)) { //玩家赢
T += t;
printf("Win %d! Total = %d.\n", t, T);
}
else if(t <= T) { //玩家输
T -= t;
printf("Lose %d. Total = %d.\n", t, T);
if(T == 0) { //玩家输光
printf("Game Over.");
break;
}
}
}
return 0;
}

PAT乙级1071小赌怡情游戏解析
本文解析PAT乙级1071小赌怡情游戏题目,详细介绍了游戏规则,包括玩家如何下注、赢取或失去筹码的过程。通过示例代码(C/C++)展示了如何实现游戏逻辑,包括判断玩家下注是否合理,以及在不同情况下如何更新玩家的筹码总数。
&spm=1001.2101.3001.5002&articleId=103756051&d=1&t=3&u=ad1e36a782bc49c88ebbae043605c012)
4696

被折叠的 条评论
为什么被折叠?



