版权声明:本文为博主原创文章,转载请务必注明出处和作者,谢谢合作! https://blog.csdn.net/zhanshen112/article/details/84061539
这是一道脑残题目,MD,出题者明明输出格式里面是一个空格,样例里面的输出是两个空格,害得我检查了好久,吭……
题目:
1071 小赌怡情 (15 分)
常言道“小赌怡情”。这是一个很简单的小游戏:首先由计算机给出第一个整数;然后玩家下注赌第二个整数将会比第一个数大还是小;玩家下注 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.
算法:
思路其实很简单,主要是搞清楚判断的顺序,先判断还有没有本金,再上赌桌,然后判断n1,n2大小,调整即可,同时每一局接着上一局,直到GAME OVER.
代码:
// 1071 小赌怡情 v1
#include <iostream>
using namespace std;
int main(){
int T,K,i; cin>>T>>K;
for(i=0;i<K;i++){
int n1,b,t,n2; cin>>n1>>b>>t>>n2;
if(T>0){
if(b==0){ //predict litttle
if(T>=t){ //money is enough
if(n2<n1){
T+=t;
printf("Win %d! Total = %d.\n",t,T);
}
else{
T-=t;
printf("Lose %d. Total = %d.\n",t,T);
}
}
else //money is not enough
printf("Not enough tokens. Total = %d.\n",T);
}
if(b==1){ //predict large
if(T>=t){ //money is enough
if(n2>n1){
T+=t;
printf("Win %d! Total = %d.\n",t,T);
}
else{
T-=t;
printf("Lose %d. Total = %d.\n",t,T);
}
}
else //money is not enough
printf("Not enough tokens. Total = %d.\n",T);
}
}
else{
cout<<"Game Over.";
break;
}
}
return 0;
}