小赌怡情 (PATB-1071)
题面
常言道“小赌怡情”。这是一个很简单的小游戏:首先由计算机给出第一个整数;然后玩家下注赌第二个整数将会比第一个数大还是小;玩家下注 t 个筹码后,计算机给出第二个数。若玩家猜对了,则系统奖励玩家 t 个筹码;否则扣除玩家 t 个筹码。
注意:玩家下注的筹码数不能超过自己帐户上拥有的筹码数。当玩家输光了全部筹码后,游戏就结束。
输入
输入在第一行给出 2 个正整数 T 和 K(≤ 100),分别是系统在初始状态下赠送给玩家的筹码数、以及需要处理的游戏次数。随后 K 行,每行对应一次游戏,顺序给出 4 个数字:
1n1 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
1100 4
28 0 100 2
33 1 50 1
45 1 200 6
57 0 200 8
样例输出
1Win 100! Total = 200.
2Lose 50. Total = 150.
3Not enough tokens. Total = 150.
4Not enough tokens. Total = 150.
样例输入2
1100 4
28 0 100 2
33 1 200 1
45 1 200 6
57 0 200 8
样例输出
1Win 100! Total = 200.
2Lose 200. Total = 0.
3Game Over.
提示
无
思路
代码
1int main()
2{
3 int sum, n;
4 scanf("%d %d", &sum, &n);
5
6 for(int i=0; i<n; i++)
7 {
8 int n1, b, t, n2;
9 scanf("%d %d %d %d", &n1, &b, &t, &n2);
10 if(t > sum)
11 {
12 printf("Not enough tokens. Total = %d.\n", sum);
13 continue;
14 }
15 if(b == (n1<n2))
16 {
17 sum += t;
18 printf("Win %d! Total = %d.\n", t, sum);
19 }
20 else
21 {
22 sum -= t;
23 printf("Lose %d. Total = %d.\n", t, sum);
24 }
25 if(sum == 0)
26 {
27 printf("Game Over.\n");
28 break;
29 }
30 }
31 return 0;
32}