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

C/C++编程学习 – 第5周 ④ 石头剪刀布「建议收藏」题目描述石头剪刀布是常见的猜拳游戏。石头胜剪刀,剪刀胜布,布胜石头。如果两个人出拳一样,则不分胜负。一天,小A和小B正好在玩石头剪刀布。已知他们的出拳都是有周期性规律的,比如:“石头-布-石头-剪刀-石头-布-石头-剪刀……”,就是以“石头-布-石头-剪刀”为周期不断循环的。请问,小A和小B比了N轮之后,谁赢的轮数多?输入格式输入包含三行。第一行包含三个整数:N,NA,NB,分别表示比了N轮,小A出拳的周期长度,小B出拳的周期长度。0

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

题目链接

题目描述

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

一天,小 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

10 3 4
0 2 5
0 5 0 2

Sample Output

A

思路

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

C语言代码:

#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++代码:

#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.net/163853.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • spring beanutils.copyproperties_bean property

    spring beanutils.copyproperties_bean property背景最近项目中在和第三方进行联调一个接口,我们这边发送http请求给对方,然后接收对方的回应,代码都是老代码。根据注释,对方的SDK中写好的Request类有一个无法序列化的bug,所以这边重新写了一个Request类,基本属性都是相同的,但是重点是有一个属性是静态内部类,还有两个是list属性,类似于下面这样:privateListorders;privateAddRequest.Tick…

    2022年9月27日
    3
  • 现在在人工智能发展方面已经有了一些泡沫_人工智能毁灭人类

    现在在人工智能发展方面已经有了一些泡沫_人工智能毁灭人类本文3560字,建议阅读9分钟。本文对人工智能在2020年的发展态势进行分析。对付泡沫的有效方法,就是用另一个更大的泡沫包住它,这也是常说的「嵌套式泡沫」。如果要追求可持续繁荣,必须要同时做到两件事:小心地把里面的虚假消掉、认真地把外面的空间做大。身处人工智能巨轮上的我们,越来越频繁地听人谈论起人工智能过快增长而导致泡沫丛生,独角兽越来越多,但跑出资本怪圈独立生长的却寥寥…

    2022年9月30日
    3
  • 电脑爱好者2012年5-12期「建议收藏」

    电脑爱好者2012年5-12期「建议收藏」电脑爱好者2012年第05期全彩高清PDF免费高速下载.pdf电脑爱好者2012年第06期全彩高清PDF免费高速下载.pdf电脑爱好者2012年第07期全彩高清PDF免费高速下载.pdf电脑爱好者201…

    2022年6月14日
    33
  • 华为模拟器ensp怎么安装_华为模拟器怎么安装

    华为模拟器ensp怎么安装_华为模拟器怎么安装简单介绍一下eNSP:eNSP是一款由华为提供的免费的图形化网络仿真工具平台,它将完美呈现真实设备实景(包括华为最新的ARG3路由器和X7系列的交换机),支持大型网络模拟,让你有机会在没有真实设备

    2022年8月2日
    6
  • 集成学习-stacking算法

    众所周知,集成学习算法,它将多个弱分类器集成起来,以达到较高的分类准确率。常见的集成学习方法:boosting bagging stacking今天主要讲stacking.Stacking的基本思想将个体学习器结合在一起的时候使用的方法叫做结合策略。对于分类问题,我们可以使用投票法来选择输出最多的类。对于回归问题,我们可以将分类器输出的结果求平均值。…

    2022年4月16日
    67
  • webstorm2019.1激活码_通用破解码「建议收藏」

    webstorm2019.1激活码_通用破解码,https://javaforall.net/100143.html。详细ieda激活码不妨到全栈程序员必看教程网一起来了解一下吧!

    2022年3月16日
    581

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号