Loading [MathJax]/jax/output/CommonHTML/config.js
前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >专栏 >C/C++编程学习 – 第5周 ④ 石头剪刀布「建议收藏」

C/C++编程学习 – 第5周 ④ 石头剪刀布「建议收藏」

作者头像
全栈程序员站长
发布于 2022-09-15 02:55:38
发布于 2022-09-15 02:55:38
1.8K02
代码可运行
举报
运行总次数:2
代码可运行

大家好,又见面了,我是你们的朋友全栈君。

题目链接

题目描述

石头剪刀布是常见的猜拳游戏。石头胜剪刀,剪刀胜布,布胜石头。如果两个人出拳一样,则不分胜负。

一天,小 A 和小 B 正好在玩石头剪刀布。已知他们的出拳都是有周期性规律的,比如:“石头-布-石头-剪刀-石头-布-石头-剪刀……”,就是以“石头-布-石头-剪刀”为周期不断循环的。请问,小 A 和小 B 比了 N 轮之后,谁赢的轮数多?

输入格式 输入包含三行。

第一行包含三个整数: N,NA,NB,分别表示比了 N 轮,小 A 出拳的周期长度,小 B 出拳的周期长度。0<N,NA,NB<100。

第二行包含 NA 个整数,表示小 A 出拳的规律。

第三行包含 NB 个整数,表示小 B 出拳的规律。

其中,0 表示“石头”,2 表示“剪刀”,5 表示“布”。相邻两个整数之间用单个空格隔开。

输出格式 输出一行,如果小 A 赢的轮数多,输出”A”;如果小 B 赢的轮数多,输出”B”;如果两人打平,输出 “draw”。

提示 对于测试数据,猜拳过程为:

A:0 2 5 0 2 5 0 2 5 0

B:0 5 0 2 0 5 0 2 0 5

A 赢了 4 轮,B 赢了 2 轮,双方打平 4 轮,所以 A 赢的轮数多。

Sample Input

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
10 3 4
0 2 5
0 5 0 2

Sample Output

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
A

思路

模拟石头剪刀布的过程,可以写一个函数判断一下谁赢了。

C语言代码:

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
#include <stdio.h>
#include <math.h>
#include <string.h>
const long long N = 1e6 + 10;
long long n, m, cnt = 0, ans = 0, sum = 0;
long long is_a_win(long long a, long long b)//0石头 2剪刀 5布;//写个函数判断谁赢啦
{ 
   
	if((a == 0 && b == 2) || (a == 2 && b == 5) || (a == 5 && b == 0)) return 1;//A赢啦
	else if(a==b) return 0;//平手
	else return -1;//B赢啦
}
int main()
{ 
   
    long long a[N], b[N], A, B;
	scanf("%lld %lld %lld",&n, &A, &B);
	for(long long i = 0; i < A; i++)//录入A的规律
		scanf("%lld", &a[i]);
	for(long long i = 0; i < B; i++)//录入B的规律
		scanf("%lld", &b[i]);
    for(long long i = 0; i < n; i++)//模拟n场猜拳
    { 
   
    	long long nowa, nowb;//这一局,第i场
    	nowa = a[i % A];//A出的是nowa
    	nowb = b[i % B];//B出的是nowb
    	cnt += is_a_win(nowa, nowb);//a赢啦,cnt就加一,B赢啦,就减一
    }
    if(cnt > 0) printf("A");//cnt>0 说明A赢得多
    else if(cnt < 0) printf("B");//cnt<0 说明B赢得多
    else printf("draw");//cnt==0, 平手 
	return 0;
}

C++代码:

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
#include<bits/stdc++.h>
using namespace std;
int main()
{ 
   
	int n, a, b, numa[105], numb[105];
	while(cin >> n >> a >> b)
	{ 
   
		int A = 0, B = 0;
		memset(numa, 0, sizeof(numa));
		memset(numb, 0, sizeof(numb));
		for(int i = 0; i < a; i++)
			cin >> numa[i];
		for(int i = 0; i < b; i++)
			cin >> numb[i];
		for(int i = 0; i < n; i++)
			if((numa[i % a] == 0 && numb[i % b] == 2) || (numa[i % a] == 2 && numb[i % b] == 5) || (numa[i % a] == 5 && numb[i % b] == 0)) A++;
			else if((numa[i % a] == 2 && numb[i % b] == 0) || (numa[i % a] == 5 && numb[i % b] == 2) || (numa[i % a] == 0 && numb[i % b] == 5)) B++;
		if(A > B) cout << "A" << endl;
		else if(A < B) cout << "B" << endl;
		else if(A == B) cout << "draw" << endl;
	}
	return 0;
}

没有C语言基础的同学们,可以先学习一下C语言语法,我会整理好,后面发出来 我已经写好了,可以去C语言程序设计专栏第一周的内容

本周其他练习:

C语言程序设计专栏

C/C++编程学习 – 第5周 ① Hello World

C/C++编程学习 – 第5周 ② 向左看齐

C/C++编程学习 – 第5周 ③ 圆锥体的体积

C/C++编程学习 – 第5周 ④ 石头剪刀布

C/C++编程学习 – 第5周 ⑤ 人见人爱A+B

C/C++编程学习 – 第5周 ⑥ 四舍五入

C/C++编程学习 – 第5周 ⑦ 等差数列求和(1)

C/C++编程学习 – 第5周 ⑧ 判断直角三角形

发布者:全栈程序员栈长,转载请注明出处:https://javaforall.cn/163853.html原文链接:https://javaforall.cn

本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
暂无评论
推荐阅读
编辑精选文章
换一批
08:石头剪刀布
08:石头剪刀布 总时间限制: 1000ms 内存限制: 65536kB描述 石头剪刀布是常见的猜拳游戏。石头胜剪刀,剪刀胜布,布胜石头。如果两个人出拳一样,则不分胜负。 一天,小A和小B正好在玩石头剪刀布。已知他们的出拳都是有周期性规律的,比如:“石头-布-石头-剪刀-石头-布-石头-剪刀……”,就是以“石头-布-石头-剪刀”为周期不断循环的。请问,小A和小B比了N轮之后,谁赢的轮数多? 输入输入包含三行。 第一行包含三个整数:N,NA,NB,分别表示比了N轮,小A出拳的周期长度,小B出拳的周期长度
attack
2018/04/03
1.9K0
百练 石头剪刀布
总时间限制: 1000ms内存限制: 65536kB描述 石头剪刀布是常见的猜拳游戏。石头胜剪刀,剪刀胜布,布胜石头。如果两个人出拳一样,则不分胜负。 一天,小A和小B正好在玩石头剪刀布。已知他们的出拳都是有周期性规律的,比如:“石头-布-石头-剪刀-石头-布-石头-剪刀……”,就是以“石头-布-石头-剪刀”为周期不断循环的。请问,小A和小B比了N轮之后,谁赢的轮数多? 输入输入包含三行。 第一行包含三个整数:N,NA,NB,分别表示比了N轮,小A出拳的周期长度,小B出拳的周期长度。0 < N,NA,NB
用户1631856
2018/04/12
9510
P1328 生活大爆炸版石头剪刀布
题目描述 石头剪刀布是常见的猜拳游戏:石头胜剪刀,剪刀胜布,布胜石头。如果两个人出拳一样,则不分胜负。在《生活大爆炸》第二季第8 集中出现了一种石头剪刀布的升级版游戏。 升级版游戏在传统的石头剪刀布游
attack
2018/04/12
1.7K0
P1328 生活大爆炸版石头剪刀布
联想算法题-石头剪刀布
问题描述 剪刀石头布是一种常见的猜拳游戏,当玩家人数为两人时,它的规则如下:在每一轮中,双方分别同时给出石头(Rock)、剪刀(Scissor)和布(Paper)这三种手势中的一种。石头战胜剪刀;剪刀战胜布;布战胜石头。若双方给出的手势一样则本轮平局,双方分数不变;否则胜方积1分。 现在Alice和Bob想进行若干轮猜拳游戏,但他们不想逐轮进行游戏,于是决定分别在纸上写下他们每一轮要出的手势。作为裁判的你需要根据他们所写下的手势判断他们的比分是多少。 输入描述 第一行是一个正整数T,表示他们想进行的轮数。 第二行包含T个空格隔开的字符串s_1, s_2, …, s_T,其中s_i表示Alice写下的第i轮要出的手势。 第三行包含T个空格隔开的字符串t_1, t_2, …, t_T,其中t_i表示Bob写下的第i轮要出的手势。 所有的s_i和t_i均是”Rock”,”Scissor”,”Paper”中的一种。
GeekLiHua
2025/01/21
940
C语言 编写“剪刀石头布”小游戏[通俗易懂]
大家好~ 我是一名C语言初学者,学了C语言基础后,我制作了一个小游戏:剪刀石头布。 希望大家能对我的思路和代码提出小Tips(eg.更简便的方法与程序) 我也会虚心接受大家的建议~
全栈程序员站长
2022/09/15
3.8K0
1018 锤子剪刀布 (20 分)
大家应该都会玩“锤子剪刀布”的游戏:两人同时给出手势,胜负规则如图所示:现给出两人的交锋记录,请统计双方的胜、平、负次数,并且给出双方分别出什么手势的胜算最大。
可爱见见
2019/09/09
9820
​# 使用腾讯云AI代码助手实现石头剪刀布小游戏
石头剪刀布,这个看似简单的游戏,却蕴含着无穷的乐趣。它是人类历史上最古老、流传最广的游戏之一,几乎每个人在儿时都曾与伙伴们乐此不疲地对战过。这个游戏凭借其简单的规则和高度的互动性,成为了人们茶余饭后、朋友聚会时的经典娱乐项目。它不仅考验玩家的反应速度,更蕴含着一种策略性的思考。
Front_Yue
2025/04/01
1340
​# 使用腾讯云AI代码助手实现石头剪刀布小游戏
C语言实现石头剪刀布小游戏【源码演示】
代码运行结果演示 代码如下 #include<stdio.h> #include<stdlib.h> #include<time.h> //在【C语言中文社区】公众号回复“C语言”,免费领取200G学习资料。 int main() { printf("欢迎来到石头剪刀布游戏世界\n"); printf("我是你无法打败的对手-小布\n"); char game[3][20] = { "石头","剪刀","布" }; /*i表示游戏次数,如果玩家在15次比赛后累计得分60,
C语言中文社区
2022/05/31
3.3K1
C语言实现石头剪刀布小游戏【源码演示】
【C++】B2112 石头剪子布
石头剪子布,是一种猜拳游戏,起源于中国,然后传到日本,朝鲜等地,随着亚欧贸易的不断发展它传到西欧,到了现代化逐渐国际化的世界中。简单明了的规则,使得石头剪子布没有任何知识和规则漏洞可钻,单次玩法让比赛公平,容易且充满心理博弈,使得石头剪子布这个古老的游戏同时用于“意外”与“技术”两种特性,深受世界人民喜爱。
CSDN-Z
2025/01/24
600
【C++】B2112 石头剪子布
石头剪刀布c++实现
问题描述: 编写一个程序,玩“石头”“剪刀”“布”的游戏,在这个游戏中,两位玩家通时说出“石头”“剪刀”“布” 如果一位玩家所选的对象击败了另一个玩家所选的对象,那么前者就是赢家,规则是:布吃石头,石头吃剪刀 剪刀吃布,为选择的对象和最终的结果使用枚举,使用标准头文件中定义的ran()函数,为计算生成随机的选择。 输入: choose either rock,shear,cloth(R/S/P):S 输出: I chose Rock. I won 设计思路: 产生result的两个人,设计程序为你选你的(switch随机选),我产生我的(rand()函数随机产生对3求余,switch实现产生我的三种结果), 然后将你选的和我随机产生做比较,对产生的结果做判断,当然了本题也可以是两个人的结果都随机产生,然后作比较 。
全栈程序员站长
2022/09/15
1K0
石头剪刀布c++实现
16:矩阵剪刀石头布
16:矩阵剪刀石头布 总时间限制: 5000ms 内存限制: 65536kB描述 Bart的妹妹Lisa在一个二维矩阵上创造了新的文明。矩阵上每个位置被三种生命形式之一占据:石头,剪刀,布。每天,上下左右相邻的不同生命形式将会发生战斗。在战斗中,石头永远胜剪刀,剪刀永远胜布,布永远胜石头。每一天结束之后,败者的领地将被胜者占领。 你的工作是计算出n天之后矩阵的占据情况。 输入第一行包含三个正整数r,c,n,分别表示矩阵的行数、列数以及天数。每个整数均不超过100。 接下来r行,每行c个字符,描述矩阵
attack
2018/04/03
1.5K0
教小朋友了解 C++ 的循环结构
嗨,小朋友们!准备好进入C++的循环结构奇妙世界了吗?循环结构就像魔法石一样神奇,让我们来一起探索吧!
Yunjie Ge
2023/09/01
2700
教小朋友了解 C++ 的循环结构
Contest100000575 – 《算法笔记》3.1小节——入门模拟->简单模拟
http://codeup.cn/contest.php?cid=100000575 Problem A: 剩下的树 Time Limit: 1.000 Sec Memory Limit: 32 M
可定
2020/04/20
1.1K0
YbtOJ 971「fwt」猜拳游戏
有 n=3^m 个人(标号为 0\sim n-1)在玩猜拳。共有 t 轮游戏,每轮游戏都会进行 m 次猜拳。
yzxoi
2022/09/19
2800
PAT (Basic Level) Practice (中文)1018 锤子剪刀布 (20 分)
现给出两人的交锋记录,请统计双方的胜、平、负次数,并且给出双方分别出什么手势的胜算最大。
glm233
2020/09/28
3450
PAT (Basic Level) Practice (中文)1018 锤子剪刀布 (20 分)
大整数乘法的详解
由于编程语言提供的基本数值数据类型表示的数值范围有限,不能满足较大规模的高精度数值计算,因此需要利用其他方法实现高精度数值的计算,于是产生了大数运算。尤其是乘法运算,下面就是大整数的乘法的过程(加 减法都一样的原理)。
全栈程序员站长
2022/09/05
1.5K0
大整数乘法的详解
江哥带你玩转C语言 | 07 - C语言流程控制
流程控制基本概念 默认情况下程序运行后,系统会按书写顺序从上至下依次执行程序中的每一行代码。但是这并不能满足我们所有的开发需求, 为了方便我们控制程序的运行流程,C语言提供3种流程控制结构,不同的流程控制结构可以实现不同的运行流程。 这3种流程结构分别是顺序结构、选择结构、循环结构 顺序结构: 按书写顺序从上至下依次执行 选择结构 对给定的条件进行判断,再根据判断结果来决定执行代码 循环结构 在给定条件成立的情况下,反复执行某一段代码 ---- 选择结构 C语言中提供了两大选择结
极客江南
2021/07/11
1.6K0
第十四届蓝桥杯集训——练习解题阶段(无序阶段)-ALGO-919 组合数取模
        这段时间我会把蓝桥杯官网上的所有非VIP题目都发布一遍,让大家方便去搜索,所有题目都会有几种语言的写法,帮助大家提供一个思路,当然,思路只是思路,千万别只看着答案就认为会了啊,这个方法基本上很难让你成长,成长是在思考的过程中找寻到自己的那个解题思路,并且首先肯定要依靠于题海战术来让自己的解题思维进行一定量的训练,如果没有这个量变到质变的过程你会发现对于相对需要思考的题目你解决的速度就会非常慢,这个思维过程甚至没有纸笔的绘制你根本无法在大脑中勾勒出来,所以我们前期学习的时候是学习别人的思路通过自己的方式转换思维变成自己的模式,说着听绕口,但是就是靠量来堆叠思维方式,刷题方案自主定义的话肯定就是从非常简单的开始,稍微对数据结构有一定的理解,暴力、二分法等等,一步步的成长,数据结构很多,一般也就几种啊,线性表、树、图、再就是其它了。顺序表与链表也就是线性表,当然栈,队列还有串都是属于线性表的,这个我就不在这里一一细分了,相对来说都要慢慢来一个个搞定的。蓝桥杯中对于大专来说相对是比较友好的,例如三分枚举、离散化,图,复杂数据结构还有统计都是不考的,我们找简单题刷个一两百,然后再进行中等题目的训练,当我们掌握深度搜索与广度搜索后再往动态规划上靠一靠,慢慢的就会掌握各种规律,有了规律就能大胆的长一些难度比较高的题目了,再次说明,刷题一定要循序渐进,千万别想着直接就能解决难题,那只是对自己进行劝退处理。加油,平常心,一步步前进。
红目香薰
2023/02/23
3170
第十四届蓝桥杯集训——练习解题阶段(无序阶段)-ALGO-919 组合数取模
shell脚本实例精讲_shell脚本编程实例
shell 是一个应用程序,它连接了用户和 Linux 内核,让用户能够更加高效、安全、低成本地使用 Linux 内核,这就是 Shell 的本质。
全栈程序员站长
2022/11/10
1.4K0
C学习
链接:https://pan.baidu.com/s/1TKn-gy_UDsngbSzL9Cv5mQ 提取码:txcl
裴来凡
2022/05/29
6240
C学习
相关推荐
08:石头剪刀布
更多 >
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档
本文部分代码块支持一键运行,欢迎体验
本文部分代码块支持一键运行,欢迎体验