1071 小赌怡情 (15 分)

版权声明:本文为博主原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。

本文链接:https://blog.csdn.net/shiliang97/article/details/99688571

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.

那根筋搭错了,认为 0&&0 ==1;

所以写了n1>n2&&!b这样的笑话

水题代码

#include<iostream>
using namespace std;
int n1,b,t,n2,k,t2;
int main(){
	cin>>t>>k;
	for(int i=0;i<k;i++){
		cin>>n1>>b>>t2>>n2;
		if(t2>t){
			printf("Not enough tokens.  Total = %d.\n",t);
		}else{
			if(n1>n2==!b){
				printf("Win %d!  Total = %d.\n",t2,t2+t);
				t=t+t2;
			}else{
				printf("Lose %d.  Total = %d.\n",t2,t-t2);
				t=t-t2;
				if(t==0){
					printf("Game Over.");
					return 0;
				}
			}
		}
	}
} 

柳神代码

我觉得柳神写的有问题,她写的是输光后再玩,输出Game over

我觉得题目要求是输光后就输出 Game Over

但是柳神这个也是对的

因为输光之后 再玩 scanf("%d %d %d %d", &n1, &b, &t, &n2);返回4

不玩读不到值,返回0,也会输出GameOver

不不不,还是有漏洞,如果刚好最后一局玩完了,跳出for循环就没有GameOver了

#include <iostream>
using namespace std;
int main() {
    int T, K, n1, n2, b, t;
    scanf("%d %d", &T, &K);
    for (int i = 0; i < K; i++) {
        scanf("%d %d %d %d", &n1, &b, &t, &n2);
        int ans = n1 > n2 ? 0 : 1;
        if (T == 0) {
            printf("Game Over.\n");
            return 0;
        } else if (t > T) {
            printf("Not enough tokens.  Total = %d.\n", T);
        } else if (ans == b) {
            T += t;
            printf("Win %d!  Total = %d.\n", t, T);
        } else if (ans != b) {
            T -= t;
            printf("Lose %d.  Total = %d.\n", t, T);
        } 
    }
    return 0;
}

本文参与腾讯云自媒体分享计划,欢迎正在阅读的你也加入,一起分享。

发表于

我来说两句

0 条评论
登录 后参与评论

相关文章

来自专栏机器之心

德州农工大学开源RLCard:帮你快速训练会斗地主的智能体

RLCard 是一个用于牌类游戏强化学习研究的开源工具包,其接口简单易用,支持多种牌类环境。RLCard 的目标是在强化学习与非完美信息博弈之间搭建桥梁,推动强...

20110
来自专栏算法channel

一个Python游戏项目,助你玩乐中搞定Python

在本项目中,你将学习如何使用Pygame,这个扩展让你能够使用Python编写功能齐备的全屏街机游戏。

9210
来自专栏磐创AI技术团队的专栏

一文带你实战强化学习(下) | DQN

【磐创AI导读】:本篇文章是深度强化学习专栏的第四篇,讲了第五节实战强化学习中Monte Carlo Policy Gradient 算法及Actor Crit...

9620
来自专栏Rust语言学习交流

【Rust日报】 2019-10-19 微软研究员用 Rust 从头构建 Demikernel 操作系统的 TCP/IP 协议栈

博文是使用具有不稳定特性的 Rust 1.40 nightly (518deda77)编写的。某些不稳定的功能可能已经改变或删除。

14520
来自专栏信数据得永生

ApacheCN 翻译/校对/笔记整理活动进度公告 2019.10.18

版权声明:本文为博主原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。 ...

8630
来自专栏机器之心

获顶会最佳论文,天津大学等用强化学习寻找游戏bug

软件工程领域顶级会议 34th IEEE/ACM International Conference on Automated Software Engineer...

18010
来自专栏磐创AI技术团队的专栏

姚班学霸陈立杰:16岁保送清华,18岁拿下IOI世界冠军,现摘得FOCS 2019最佳学生论文

今年的理论计算机顶会FOCS,一位来自浙江湖州的小哥哥一口气中了3篇论文,还拿下了最佳学生论文奖。

13490
来自专栏授客的专栏

Python @classmethod和@staticmethod装饰器使用介绍

静态方法:类中用 @staticmethod装饰的不带 self 参数的方法。类的静态方法可以直接使用类名调用。

6710
来自专栏用户3254834的专栏

开发一款App,公司需要什么资质

随着移动互联网的的快速发展,更多的创业选择在移动应用这个赛道进行布局,很多互联网老牌企业或者传统企业、传统事业组织都在寻求新的商业价值突破。做转型、搞创新,已原...

24120
来自专栏智能算法

深度学习算法(第32期)----强化学习入门必读

上期我们一起学习了变分自编码器及其实现的相关知识, 深度学习算法(第31期)----变分自编码器及其实现

6020

扫码关注云+社区

领取腾讯云代金券

年度创作总结 领取年终奖励