pat(B) 1018. 锤子剪刀布

代码:

#include<iostream>
#include<cstdio>
#include<cstring>
using namespace std;

char Hash[3][3];
int ans[3];

int main()
{
	int n,i,j;
	for(i=0;i<3;i++)
	{
		Hash[i][i]=1;
	}
	Hash[0][1]=0;//甲胜
	Hash[0][2]=2;
	Hash[1][0]=2;
	Hash[1][2]=0;
	Hash[2][0]=0;
	Hash[2][1]=2;

	while(scanf("%d",&n)==1)
	{
		getchar();
		memset(ans,0,sizeof(ans));
		int x[3]={0};
		int l[3]={0};
		for(i=0;i<n;i++)
		{
			char c1,c2;
			int a,b;
			scanf("%c%*c%c%*c",&c1,&c2);
			if(c1=='C')
				a=0;
			if(c1=='J')
				a=1;
			if(c1=='B')
				a=2;
			if(c2=='C')
				b=0;
			if(c2=='J')
				b=1;
			if(c2=='B')
				b=2;
			ans[Hash[a][b]]++;
			if(Hash[a][b]==0)
			{
				if(a==0)
					x[0]++;
				if(a==1)
					x[1]++;
				if(a==2)
					x[2]++;
			}
			if(Hash[a][b]==2)
			{
				if(b==0)
					l[0]++;
				if(b==1)
					l[1]++;
				if(b==2)
					l[2]++;
			}
		}
		for(i=0;i<3;i++)
		{
			if(i==2)
				printf("%d\n",ans[i]);
			else
				printf("%d ",ans[i]);
		}
		for(i=2;i>=0;i--)
		{
			if(i==0)
				printf("%d\n",ans[i]);
			else
				printf("%d ",ans[i]);
		}
		int max=-1;
		for(i=0;i<3;i++)
		{
			if(x[i]>max)
			{
				max=x[i];
				j=i;
			}
		}
		if(j==0)
		{
			if(x[2]<max)
				printf("C ");
			else
				printf("B ");
		}
		if(j==1)
		{
			if(x[2]==max)
				printf("B ");
			else if(x[0]==max)
				printf("C ");
			else
				printf("J ");
		}
		if(j==2)
			printf("B ");
		max=-1;
		for(i=0;i<3;i++)
		{
			if(l[i]>max)
			{
				max=l[i];
				j=i;
			}
		}
		if(j==0)
		{
			if(l[2]<max)
				printf("C\n");
			else
				printf("B\n");
		}
		if(j==1)
		{
			if(l[2]==max)
				printf("B\n");
			else if(l[0]==max)
				printf("C\n");
			else
				printf("J\n");
		}
		if(j==2)
			printf("B\n");
	}
	return 0;
}

版权声明:本文为博主原创文章,未经博主允许不得转载。

时间: 2024-10-12 10:14:47

pat(B) 1018. 锤子剪刀布的相关文章

PAT乙级 1018. 锤子剪刀布 (20)

1018. 锤子剪刀布 (20) 时间限制 100 ms 内存限制 65536 kB 代码长度限制 8000 B 判题程序 Standard 作者 CHEN, Yue 大家应该都会玩“锤子剪刀布”的游戏:两人同时给出手势,胜负规则如图所示: 现给出两人的交锋记录,请统计双方的胜.平.负次数,并且给出双方分别出什么手势的胜算最大. 输入格式: 输入第1行给出正整数N(<=105),即双方交锋的次数.随后N行,每行给出一次交锋的信息,即甲.乙双方同时给出的的手势.C代表“锤子”.J代表“剪刀”.B代

PAT 乙级 1018 锤子剪刀布 (20) C++版

1018. 锤子剪刀布 (20) 时间限制 100 ms 内存限制 65536 kB 代码长度限制 8000 B 判题程序 Standard 作者 CHEN, Yue 大家应该都会玩"锤子剪刀布"的游戏:两人同时给出手势,胜负规则如图所示: 现给出两人的交锋记录,请统计双方的胜.平.负次数,并且给出双方分别出什么手势的胜算最大. 输入格式: 输入第1行给出正整数N(<=105),即双方交锋的次数.随后N行,每行给出一次交锋的信息,即甲.乙双方同时给出的的手势.C代表"锤

PAT乙级1018.锤子剪刀布 (20)(20 分)

1018 锤子剪刀布 (20)(20 分) 大家应该都会玩“锤子剪刀布”的游戏:两人同时给出手势,胜负规则如图所示: 现给出两人的交锋记录,请统计双方的胜.平.负次数,并且给出双方分别出什么手势的胜算最大. 输入格式: 输入第1行给出正整数N(<=10^5^),即双方交锋的次数.随后N行,每行给出一次交锋的信息,即甲.乙双方同时给出的的手势.C代表“锤子”.J代表“剪刀”.B代表“布”,第1个字母代表甲方,第2个代表乙方,中间有1个空格. 输出格式: 输出第1.2行分别给出甲.乙的胜.平.负次数

PAT:1018. 锤子剪刀布 (20) AC

#include<stdio.h> #include<stdlib.h> int main() { int n,maxA,maxB; maxA=maxB=-1; int A[3]={0},B[3]={0}; //0,1,2位置分别存胜利,平局,失败..填入次数 int HARSH1[3]={0},HARSH2[3]={0}; //0:布,1锤子,2剪刀: scanf("%d",&n); for(int t=0 ; t<n ; ++t) { getc

PAT 1018. 锤子剪刀布

1018. 锤子剪刀布 (20) 大家应该都会玩"锤子剪刀布"的游戏:两人同时给出手势,胜负规则如图所示: 现给出两人的交锋记录,请统计双方的胜.平.负次数,并且给出双方分别出什么手势的胜算最大. 输入格式: 输入第1行给出正整数N(<=105),即双方交锋的次数.随后N行,每行给出一次交锋的信息,即甲.乙双方同时给出的的手势.C代表"锤子".J代表"剪刀".B代表"布",第1个字母代表甲方,第2个代表乙方,中间有1个空

PTA乙级 (1018 锤子剪刀布 (20分))

1018 锤子剪刀布 (20分) https://pintia.cn/problem-sets/994805260223102976/problems/994805304020025344 #include <iostream> #include <cstdio> #include <cstring> #include <string> #include <cmath> #include <algorithm> using names

PAT (Basic Level) Practise (中文)- 1018. 锤子剪刀布 (20)

http://www.patest.cn/contests/pat-b-practise/1018 大家应该都会玩“锤子剪刀布”的游戏:两人同时给出手势,胜负规则如图所示: 现给出两人的交锋记录,请统计双方的胜.平.负次数,并且给出双方分别出什么手势的胜算最大. 输入格式: 输入第1行给出正整数N(<=105),即双方交锋的次数.随后N行,每行给出一次交锋的信息,即甲.乙双方同时给出的的手势.C代表“锤子”.J代表“剪刀”.B代表“布”,第1个字母代表甲方,第2个代表乙方,中间有1个空格. 输出

1018. 锤子剪刀布 (20) (数学啊 ZJU_PAT)

题目链接:http://www.patest.cn/contests/pat-b-practise/1018 大家应该都会玩"锤子剪刀布"的游戏:两人同时给出手势,胜负规则如图所示: 现给出两人的交锋记录,请统计双方的胜.平.负次数,并且给出双方分别出什么手势的胜算最大. 输入格式: 输入第1行给出正整数N(<=105),即双方交锋的次数.随后N行,每行给出一次交锋的信息,即甲.乙双方同时给出的的手势.C代表"锤子".J代表"剪刀".B代表

1018. 锤子剪刀布 (20)

时间限制 100 ms 内存限制 65536 kB 代码长度限制 8000 B 判题程序 Standard 作者 CHEN, Yue 大家应该都会玩"锤子剪刀布"的游戏:两人同时给出手势,胜负规则如图所示: 现给出两人的交锋记录,请统计双方的胜.平.负次数,并且给出双方分别出什么手势的胜算最大. 输入格式: 输入第1行给出正整数N(<=105),即双方交锋的次数.随后N行,每行给出一次交锋的信息,即甲.乙双方同时给出的的手势.C代表"锤子".J代表"