1071. 小赌怡情(15)

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

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

输入格式:

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

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:

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.

代码:
#include <iostream>
#include <algorithm>
#include <cstdio>
#include <set>
#include <cstring>
using namespace std;

int main()
{
    long long T,K;
    long long n1,b,t,n2;
    cin>>T>>K;
    for(int i = 0;i < K;i ++)
    {
        if(T == 0)
        {
            printf("Game Over.");
            break;
        }
        cin>>n1>>b>>t>>n2;
        if(T < t)printf("Not enough tokens.  Total = %lld.",T);
        else if(n2 > n1 && b || n2 < n1 && !b)printf("Win %lld!  Total = %lld.",t,T += t);
        else printf("Lose %lld.  Total = %lld.",t,T -= t);
        if(i != K - 1)cout<<endl;
    }
}
时间: 2024-10-17 20:47:22

1071. 小赌怡情(15)的相关文章

1071 小赌怡情 (15分)

常言道“小赌怡情”.这是一个很简单的小游戏:首先由计算机给出第一个整数:然后玩家下注赌第二个整数将会比第一个数大还是小:玩家下注 t 个筹码后,计算机给出第二个数.若玩家猜对了,则系统奖励玩家 t 个筹码:否则扣除玩家 t 个筹码. 注意:玩家下注的筹码数不能超过自己帐户上拥有的筹码数.当玩家输光了全部筹码后,游戏就结束. 输入格式: 输入在第一行给出 2 个正整数 T 和 K(≤ 100),分别是系统在初始状态下赠送给玩家的筹码数.以及需要处理的游戏次数.随后 K 行,每行对应一次游戏,顺序给

PAT 1071. 小赌怡情

PAT 1071. 小赌怡情 常言道"小赌怡情".这是一个很简单的小游戏:首先由计算机给出第一个整数:然后玩家下注赌第二个整数将会比第一个数大还是小:玩家下注t个筹码后,计算机给出第二个数.若玩家猜对了,则系统奖励玩家t个筹码:否则扣除玩家t个筹码. 注意:玩家下注的筹码数不能超过自己帐户上拥有的筹码数.当玩家输光了全部筹码后,游戏就结束. 输入格式: 输入在第一行给出2个正整数T和K(<=100),分别是系统在初始状态下赠送给玩家的筹码数.以及需要处理的游戏次数.随后K行,每行

PAT 乙级 1071.小赌怡情 C++/JAVA

题目来源 常言道“小赌怡情”.这是一个很简单的小游戏:首先由计算机给出第一个整数:然后玩家下注赌第二个整数将会比第一个数大还是小:玩家下注 t 个筹码后,计算机给出第二个数.若玩家猜对了,则系统奖励玩家 t 个筹码:否则扣除玩家 t 个筹码. 注意:玩家下注的筹码数不能超过自己帐户上拥有的筹码数.当玩家输光了全部筹码后,游戏就结束. 输入格式: 输入在第一行给出 2 个正整数 T 和 K(≤ 100),分别是系统在初始状态下赠送给玩家的筹码数.以及需要处理的游戏次数.随后 K 行,每行对应一次游

1071 小赌怡情

题目链接:https://pintia.cn/problem-sets/994805260223102976/problems/994805264312549376 题解: 1 #include<iostream> 2 using namespace std; 3 4 int main() { 5 int T, K, n1, b, t, n2; 6 cin >> T >> K; 7 while (K--) { 8 cin >> n1 >> b &

DevExpress 15.1.sln

1 Microsoft Visual Studio Solution File, Format Version 12.00 2 # Visual Studio 14 3 VisualStudioVersion = 14.0.23107.0 4 MinimumVisualStudioVersion = 10.0.40219.1 5 Project("{FAE04EC0-301F-11D3-BF4B-00C04F79EFBC}") = "DevExpress.BonusSkins

Lightoj 1071 - Baker Vai (双线程DP)

题目连接: http://lightoj.com/volume_showproblem.php?problem=1071 题目大意: 一个n*m的格子,Baker Vai要从(1,1)到(n,m)再回到(1,1),每到一个格子可以收集格子上的数字(每个格子只能走一次,(1,1)这个格子除外),问最终搜集的数字之和最大为多少? 解题思路: 可以把题目转化为求两个对象同时从(1,1)出发到(n,m)途中不能相遇,状态转移的时候可以用dp[step][x][y],step代表当前步数,x,y分别代表两

ural 1071. Nikifor 2

1071. Nikifor 2 Time limit: 1.0 secondMemory limit: 64 MB Nikifor has a number x. He doesn't need it. He needs a number y. Nikifor tries to obtain the required number by erasing some digits from x. But he is not lucky in the meanwhile. May be he is t

PAT 1071. Speech Patterns (25)

1071. Speech Patterns (25) People often have a preference among synonyms of the same word. For example, some may prefer "the police", while others may prefer "the cops". Analyzing such patterns can help to narrow down a speaker's ident

HDU 1071 微积分

The area Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 65536/32768 K (Java/Others)Total Submission(s): 7611    Accepted Submission(s): 5332 Problem Description Ignatius bought a land last week, but he didn't know the area of the land becaus