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个空格。
输出格式:
输出第1、2行分别给出甲、乙的胜、平、负次数,数字间以1个空格分隔。第3行给出两个字母,分别代表甲、乙获胜次数最多的手势,中间有1个空格。如果解不唯一,则输出按字母序最小的解。
输入样例:
10
C J
J B
C B
B B
B C
C C
C B
J B
B C
J J
输出样例:
5 3 2
2 3 5
B B 分析:图示中规则是一个循环圈
#include<stdio.h> int a2i(char c)
{
if(c=='B') return ;
else if(c=='C') return ;
else return ;
}
char i2a(int i)
{
if(i==) return 'B';
else if(i==) return 'C';
else return 'J';
} int main()
{
int n=;//双方交锋的次数
scanf("%d",&n); char jia,yi;
int sheng=,ping=,fu=; // 甲
int ying1[]={},ying2[]={}; //B“0 布” C“1 锤子” J“2 剪刀”、
for(int i=;i<n;i++)
{
getchar();
scanf("%c",&jia);
getchar();
scanf("%c",&yi); if(a2i(jia)==a2i(yi)) ping++;
else if((a2i(jia)-a2i(yi)+)%==) sheng++,ying1[a2i(jia)]++;
else fu++,ying2[a2i(yi)]++;
}
printf("%d %d %d\n",sheng,ping,fu);//输出第1、2行分别给出甲、乙的胜、平、负次数,数字间以1个空格分隔
printf("%d %d %d\n",fu,ping,sheng); int k=;
for(int i=;i<;i++)
if(ying1[i]>ying1[k]) k=i;
printf("%c",i2a(k));//第3行给出两个字母,分别代表甲、乙获胜次数最多的手势,中间有1个空格。如果解不唯一,则输出按字母序最小的解。 k=;
for(int i=;i<;i++)
if(ying2[i]>ying2[k]) k=i;
printf(" %c",i2a(k));
return ;
}
#include<stdio.h>
int main()
{
int n=;
scanf("%d",&n); char jia,yi,chu[]={'B','C','J'};
int sheng=,ping=,fu=; // 甲
int ying1[]={,,},ying2[]={,,}; //B“0 布” C“1 锤子”、J“2 剪刀”、
for(int i=;i<n;i++)
{
getchar();
scanf("%c",&jia);
getchar();
scanf("%c",&yi); if(jia=='J' && yi=='B')
{
sheng++;
ying1[]++;
}
else if(jia=='B' && yi=='C')
{
sheng++;
ying1[]++;
}
else if(jia=='C' && yi=='J')
{
sheng++;
ying1[]++;
}
else if(jia=='B' && yi=='J')
{
fu++;
ying2[]++;
}
else if(jia=='C' && yi=='B')
{
fu++;
ying2[]++;
}
else if(jia=='J' && yi=='C')
{
fu++;
ying2[]++;
}
else
ping++;
} printf("%d %d %d\n",sheng,ping,fu);
printf("%d %d %d\n",fu,ping,sheng); int max=,k=;
for(int i=;i<;i++)
if(ying1[i]>max)
{
max=ying1[i];
k=i;
}
printf("%c",chu[k]); max=;
k=;
for(int i=;i<;i++)
if(ying2[i]>max)
{
max=ying2[i];
k=i;
}
printf(" %c",chu[k]);
return ;
}
PAT (Basic Level) Practise (中文)- 1018. 锤子剪刀布 (20)的更多相关文章
- PAT (Basic Level) Practise:1018. 锤子剪刀布
[题目链接] 大家应该都会玩“锤子剪刀布”的游戏:两人同时给出手势,胜负规则如图所示: 现给出两人的交锋记录,请统计双方的胜.平.负次数,并且给出双方分别出什么手势的胜算最大. 输入格式: 输入第1行 ...
- PAT乙级 1018. 锤子剪刀布 (20)
1018. 锤子剪刀布 (20) 时间限制 100 ms 内存限制 65536 kB 代码长度限制 8000 B 判题程序 Standard 作者 CHEN, Yue 大家应该都会玩“锤子剪刀布”的游 ...
- PAT 乙级 1018 锤子剪刀布 (20) C++版
1018. 锤子剪刀布 (20) 时间限制 100 ms 内存限制 65536 kB 代码长度限制 8000 B 判题程序 Standard 作者 CHEN, Yue 大家应该都会玩“锤子剪刀布”的游 ...
- 【PAT】1018 锤子剪刀布 (20)(20 分)
1018 锤子剪刀布 (20)(20 分) 大家应该都会玩“锤子剪刀布”的游戏:两人同时给出手势,胜负规则如图所示: 现给出两人的交锋记录,请统计双方的胜.平.负次数,并且给出双方分别出什么手势的胜算 ...
- PAT-乙级-1018. 锤子剪刀布 (20)
1018. 锤子剪刀布 (20) 时间限制 100 ms 内存限制 65536 kB 代码长度限制 8000 B 判题程序 Standard 作者 CHEN, Yue 大家应该都会玩“锤子剪刀布”的游 ...
- PAT Basic 1018 锤子剪刀布 (20 分)
大家应该都会玩“锤子剪刀布”的游戏:两人同时给出手势,胜负规则如图所示: 现给出两人的交锋记录,请统计双方的胜.平.负次数,并且给出双方分别出什么手势的胜算最大. 输入格式: 输入第 1 行给出正整数 ...
- PAT 1018. 锤子剪刀布 (20)
现给出两人的交锋记录,请统计双方的胜.平.负次数,并且给出双方分别出什么手势的胜算最大. 输入格式: 输入第1行给出正整数N(<=105),即双方交锋的次数.随后N行,每行给出一次交锋的信息,即 ...
- PAT 1018 锤子剪刀布(20)
1018 锤子剪刀布 (20)(20 分) 大家应该都会玩"锤子剪刀布"的游戏:两人同时给出手势,胜负规则如图所示: 现给出两人的交锋记录,请统计双方的胜.平.负次数,并且给出双方 ...
- PAT (Basic Level) Practise (中文)-1039. 到底买不买(20)
PAT (Basic Level) Practise (中文)-1039. 到底买不买(20) http://www.patest.cn/contests/pat-b-practise/1039 小红 ...
随机推荐
- 转载-【深度学习】深入理解Batch Normalization批标准化
全文转载于郭耀华-[深度学习]深入理解Batch Normalization批标准化: 文章链接Batch Normalization: Accelerating Deep Network T ...
- Tyvj P1520 树的直径
P1520 树的直径 http://www.tyvj.cn/p/1520 时间: 1000ms / 空间: 131072KiB / Java类名: Main 描述 树的直径,即这棵树中距离最远的两个结 ...
- 如何使用Node.js搭建一个服务器
在node环境中运行下面的代码 "use strict"; const http = require("http"), path = require(" ...
- JS中的MOD运算
最近研究汉诺塔非递归的时候,看到书上写了个MOD,久违啊,感觉好久没看到过了,都忘了怎么用了. 某人:我知道,这不就是取余嘛,直接%就行了. 嗯......,如果是python语言,你说的很对,但是我 ...
- BitMap的原理以及运用
位图(Bitmap),即位(Bit)的集合,是一种数据结构,可用于记录大量的0-1状态,在很多地方都会用到,比如Linux内核(如inode,磁盘块).Bloom Filter算法等,其优势是可以在一 ...
- 关于表格——增加删除行,鼠标选定(利用JavaScript)
涉及到的知识点: 1.onmouseover,onmouseout 2.dom getElementByTagName 3.新建节点元素createElement; <!DOCTYPE html ...
- 解决sublime text无法安装插件问题
解决sublime text无法安装插件问题最近在sublime text3中使用命令ctrl+shift+p命令安装插件发现不能安装了,一会儿报错 这个错误表示没有可用的安装包,经过一番探索发现是配 ...
- 黑马旅游网 ajax实现html页面共享
- King's Pilots
题目链接 (双层图, 一层维护工作,一层维护政策) #include <bits/stdc++.h> using namespace std; inline int read() { ...
- D. Mike and distribution 首先学习了一个玄学的东西
http://codeforces.com/contest/798/problem/D D. Mike and distribution time limit per test 2 seconds m ...