标签:tar 循环 return problem 实现 ret http game one
常言道“小赌怡情”。这是一个很简单的小游戏:首先由计算机给出第一个整数;然后玩家下注赌第二个整数将会比第一个数大还是小;玩家下注 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.
并结束程序。100 4
8 0 100 2
3 1 50 1
5 1 200 6
7 0 200 8
Win 100! Total = 200.
Lose 50. Total = 150.
Not enough tokens. Total = 150.
Not enough tokens. Total = 150.
100 4
8 0 100 2
3 1 200 1
5 1 200 6
7 0 200 8
Win 100! Total = 200.
Lose 200. Total = 0.
Game Over.
循环K次,每次先对剩余筹码进行判断,再判断玩家的输赢,如果玩家输了,扣除筹码之后还要判断是否等于0,筹码为0就GameOver
1 #include <iostream> 2 using namespace std; 3 4 int main() 5 { 6 int totalMoney = 0; //总筹码 7 int gameRound = 0; //需要处理的游戏次数 8 int n1; //计算机给出的0-9的数 9 int b; //b=0:赌小 b=1:赌大 10 int n2; //计算机给出的0-9的数 n1!=n2 11 int t; //玩家下注量 12 13 cin >> totalMoney >> gameRound; 14 15 for (int i = 0; i < gameRound; ++i) 16 { 17 cin >> n1 >> b >> t >> n2; 18 19 if (t > totalMoney) 20 { 21 printf("Not enough tokens. Total = %d.\n", totalMoney); 22 continue; 23 } 24 25 if ((b == 0 && n1 > n2) || (b == 1 && n2 > n1)) 26 { 27 //赢了 28 totalMoney += t; 29 printf("Win %d! Total = %d.\n", t, totalMoney); 30 continue; 31 } 32 if ((b == 0 && n1 < n2) || (b == 1 && n2 < n1)) 33 { 34 //输了 35 totalMoney -= t; 36 printf("Lose %d. Total = %d.\n", t, totalMoney); 37 } 38 39 if (totalMoney <= 0) 40 { 41 printf("Game Over.\n"); 42 i = gameRound + 1; //退出循环 43 } 44 } 45 return 0; 46 }
标签:tar 循环 return problem 实现 ret http game one
原文地址:https://www.cnblogs.com/47Pineapple/p/11674733.html