题目

PAT (Basic Level) Practice (中文): 1071

常言道“小赌怡情”。这是一个很简单的小游戏:首先由计算机给出第一个整数;然后玩家下注赌第二个整数将会比第一个数大还是小;玩家下注 t 个筹码后,计算机给出第二个数。若玩家猜对了,则系统奖励玩家 t 个筹码;否则扣除玩家 t 个筹码。
注意:玩家下注的筹码数不能超过自己帐户上拥有的筹码数。当玩家输光了全部筹码后,游戏就结束。

1. 输入格式:

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

n1 b t n2

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

2. 输出格式:

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

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

3. 样例:

3.1. 输入样例 1:

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

3.2. 输出样例 1:

Win 100!  Total = 200.
Lose 50.  Total = 150.
Not enough tokens.  Total = 150.
Not enough tokens.  Total = 150.

3.3. 输入样例 2:

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

3.4. 输出样例 2:

Win 100!  Total = 200.
Lose 200.  Total = 0.
Game Over.

作答

1. 代码

#include "stdio.h"

int main(int argc, char * argv[]) {
    int x, k, i, n1, b, t, n2, flag = 0;
    scanf("%d%d", &x, &k);
    for (i = 0; i < k; ++i) {
        scanf("%d%d%d%d", &n1, &b, &t, &n2);
        printf("%s", flag?"\n":""); flag = 1;
        if(t > x){
            printf("Not enough tokens.  Total = %d.", x);
            continue;
        }
        if(n2>n1 == b){ // 1: 赌大 0: 赌小
            x+=t;
            printf("Win %d!  Total = %d.", t, x);
        }else{
            x-=t;
            printf("Lose %d.  Total = %d.", t, x>0?x:0);
        }
        if(x<=0) {
          printf("%s", flag?"\n":""); flag = 1;
                printf("Game Over.");
                break;
            }
    }
    return 0;
}

2. 评测结果

提交时间 状态 分数 题目 编译器 耗时 用户
2019/3/10 22:40:14 答案正确 15 1071 C (gcc) 2 ms soulans
测试点 结果 耗时 内存
0 答案正确 2 ms 484 KB
1 答案正确 2 ms 260 KB
2 答案正确 1 ms 256 KB
3 答案正确 1 ms 256 KB
4 答案正确 2 ms 256 KB
5 答案正确 1 ms 256 KB