IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> C++知识库 -> C语言基础-猜拳问题 -> 正文阅读

[C++知识库]C语言基础-猜拳问题

题目描述

石头剪刀布是常见的猜拳游戏。石头胜剪刀,剪刀胜布,布胜石头。如果两个人出拳一样, 则不分胜负。
一天,小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.

样例输入

10 3 4
0 2 5
0 5 0 2

样例输出

A
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

代码实现(做法一)

#include "stdio.h"

int main(){
	int N,NA,NB;//局数、AB的周期 
	int ACnt=0,BCnt=0;//A、B赢的局数 
	printf("请输入局数以及A、B的周期:");
	scanf("%d%d%d",&N,&NA,&NB);

	int A[999],B[999];
	printf("请输入A的出拳规律:");
	for(int i=1;i<=NA;i++){
		scanf("%d",&A[i]);//利用数组存放A 
	}

	printf("请输入B的出拳规律:");
	
	for(int i=1;i<=NB;i++){
		scanf("%d",&B[i]);//利用数组存放B 
	}


	for(int i=1;i<=N;i++){
		if(i>NA)
			A[i]=A[i-(i-1)/NA*NA]; //循环A数组的内容 
		if(i>NB)
			B[i]=B[i-(i-1)/NB*NB]; //循环B数组的内容  
		
		//猜拳结果	
		if((A[i]==0&&B[i]==2)||(A[i]==2&&B[i]==5)||(A[i]==5&&B[i]==0)){
			ACnt++;	
		}
		else if ((B[i]==0&&A[i]==2)||(B[i]==2&&A[i]==5)||(B[i]==5&&A[i]==0)){
			BCnt++;	
		}

	}
	if(ACnt>BCnt){
		printf("A\n");
	}
	else if(ACnt<BCnt){
		printf("B\n");
	}
	else{
		printf("draw\n");
	}
	printf("A:");
	for(int i=1;i<=N;i++){
		printf("%d ",A[i]);
	}
	printf("\nB:");
	for(int i=1;i<=N;i++){
		printf("%d ",B[i]);
	}
	printf("\nA赢了%d轮,B赢了%d轮,双方打平%d轮",ACnt,BCnt,N-ACnt-BCnt);
	
	return 0;
}

输出结果
猜拳问题1
代码实现(做法二)

#include "stdio.h"

//1为胜利 0为平局 -1是失败 
int checkWin(int q1,int q2){
	
	if(q1==q2)
		return 0;
	
	if(q1==0){
		if(q2==2)	return 1;
		if(q2==5) 	return -1;
	}
	
	if(q1==2){
		if(q2==5)	return 1;
		if(q2==0) 	return -1;
	}
	
	if(q1==5){
		if(q2==0)	return 1;
		if(q2==2) 	return -1;
	}
}

int main(){
	
	int n,na,nb;
	int awin=0,bwin=0;//A、B胜利的局数 
	int arr_a[100],arr_b[100];//存储出拳周期,最后出拳周期是100组
	
	scanf("%d%d%d",&n,&na,&nb);
	
	//录入小A的出拳周期 
	for(int i=0;i<na;i++){
		scanf("%d",&arr_a[i]);
	} 
	
	//录入小B的出拳周期 
	for(int i=0;i<nb;i++){
		scanf("%d",&arr_b[i]);
	} 
	
	
	int idx_a=0,idx_b=0;//记录小A和小B的出拳的位置 
	
	for(int i=1;i<=n;i++){
		//比较AB的出拳 
		int result = checkWin(arr_a[idx_a],arr_b[idx_b]);
		if(result==1)	
			awin++;
		else if(result==-1)
			bwin++;
		printf("a %d vs b %d %d	[%d %d]\n",arr_a[idx_a],arr_b[idx_b],result,awin,bwin);
		//检测周期是否到达,如果到达则重头开始 
		idx_a++;
		idx_b++;
		if(idx_a==na)	idx_a=0;
		if(idx_b==nb)	idx_b=0;
	}
	
	if(awin>bwin){
		printf("A\n");
	}
	else if(awin<bwin){
		printf("B\n");
	}
	else{
		printf("draw\n");
	}
	return 0;
} 

输出结果
猜拳问题2

  C++知识库 最新文章
【C++】友元、嵌套类、异常、RTTI、类型转换
通讯录的思路与实现(C语言)
C++PrimerPlus 第七章 函数-C++的编程模块(
Problem C: 算法9-9~9-12:平衡二叉树的基本
MSVC C++ UTF-8编程
C++进阶 多态原理
简单string类c++实现
我的年度总结
【C语言】以深厚地基筑伟岸高楼-基础篇(六
c语言常见错误合集
上一篇文章      下一篇文章      查看所有文章
加:2021-08-01 14:19:22  更:2021-08-01 14:21:47 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2024年11日历 -2024/11/23 5:26:32-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码