1071. 小赌怡情

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 <stdio.h>
#include <stdlib.h>

int main(int argc, char const *argv[])
{
	int T, K, n1, b, t, n2, total = 0;
	scanf("%d %d",&T, &K);
	total += T;		// 加上系统给的筹码
	while (K--)
	{
		scanf("%d %d %d %d", &n1, &b, &t, &n2);
		if (t > total)	// 如果超过拥有的筹码
			printf("Not enough tokens.  Total = %d.\n", total);
		else if ((n1 > n2 && b == 0) || (n1 < n2 && b == 1))	// 如果赌赢了
			printf("Win %d!  Total = %d.\n", t, total += t);
		else if ((n1 > n2 && b == 1) || (n1 < n2 && b == 0))	// 如果赌输了
		{
			total -= t;
			printf("Lose %d.  Total = %d.\n", t, total);
			if (total <= 0)		// 如果没有筹码了
			{
				printf("Game Over.\n");
				break;
			}
		}
	}
	return 0;
}
如果对您有帮助,就点个赞呗~

猜你喜欢

转载自blog.csdn.net/Invokar/article/details/79963397