【题解】PATB-1071 小赌怡情

小赌怡情 (PATB-1071)

题面

常言道“小赌怡情”。这是一个很简单的小游戏:首先由计算机给出第一个整数;然后玩家下注赌第二个整数将会比第一个数大还是小;玩家下注 t 个筹码后,计算机给出第二个数。若玩家猜对了,则系统奖励玩家 t 个筹码;否则扣除玩家 t 个筹码。

注意:玩家下注的筹码数不能超过自己帐户上拥有的筹码数。当玩家输光了全部筹码后,游戏就结束。

输入

输入在第一行给出 2 个正整数 T 和 K(≤ 100),分别是系统在初始状态下赠送给玩家的筹码数、以及需要处理的游戏次数。随后 K 行,每行对应一次游戏,顺序给出 4 个数字:

1
n1 b t n2

其中 n1n2 是计算机先后给出的两个[0, 9]内的整数,保证两个数字不相等。b 为 0 表示玩家赌,为 1 表示玩家赌t 表示玩家下注的筹码数,保证在整型范围内。

输出

对每一次游戏,根据下列情况对应输出(其中 t 是玩家下注量,x 是玩家当前持有的筹码量):

  • 玩家赢,输出 Win t! Total = x.
  • 玩家输,输出 Lose t. Total = x.
  • 玩家下注超过持有的筹码量,输出 Not enough tokens. Total = x.
  • 玩家输光后,输出 Game Over. 并结束程序。

样例输入1

1
2
3
4
5
100 4
8 0 100 2
3 1 50 1
5 1 200 6
7 0 200 8

样例输出

1
2
3
4
Win 100!  Total = 200.
Lose 50. Total = 150.
Not enough tokens. Total = 150.
Not enough tokens. Total = 150.

样例输入2

1
2
3
4
5
100 4
8 0 100 2
3 1 200 1
5 1 200 6
7 0 200 8

样例输出

1
2
3
Win 100!  Total = 200.
Lose 200. Total = 0.
Game Over.

提示

思路

代码

查看代码
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
int main()
{
int sum, n;
scanf("%d %d", &sum, &n);

for(int i=0; i<n; i++)
{
int n1, b, t, n2;
scanf("%d %d %d %d", &n1, &b, &t, &n2);
if(t > sum)
{
printf("Not enough tokens. Total = %d.\n", sum);
continue;
}
if(b == (n1<n2))
{
sum += t;
printf("Win %d! Total = %d.\n", t, sum);
}
else
{
sum -= t;
printf("Lose %d. Total = %d.\n", t, sum);
}
if(sum == 0)
{
printf("Game Over.\n");
break;
}
}
return 0;
}
_/_/_/_/_/ EOF _/_/_/_/_/