PAT B1018.锤子剪刀布(20)
一个没有通过,不知道为何
#include <cstdio>
int change(char c) {
if(c == 'B') return 0;
if(c == 'C') return 1;
if(c == 'J') return 2;
}
int judge(int a, int b) {
if(a == b) return 3;
else if(a == 'B' && b == 'C') return 1;
else if(a == 'B' && b == 'J') return 2;
else if(a == 'C' && b == 'B') return 2;
else if(a == 'C' && b == 'J') return 1;
else if(a == 'J' && b == 'B') return 1;
else if(a == 'J' && b == 'C') return 2;
}
int main() {
char str[] = {'B', 'C', 'J'};
int n = 0;
scanf("%d", &n);
//count[0]:甲赢 count[1]:甲负 count[2]:甲平
//count[3]:乙赢 count[4]:乙负 count[5]:乙平
int count[6] = {0};
//times[0]~times[5]:甲乙分别用锤子,剪刀,布赢的次数
int times[6] = {0};
int id1 = 0, id2 = 0; //甲乙分别赢的最多的手势
for(int i = 0; i < n; i++) {
char a, b;
getchar();
scanf("%c %c", &a, &b);
int temp = judge(a, b);
if(temp == 1) {
count[0]++;
count[4]++;
times[change(a)]++;//甲赢使用的手势加一
/*for(int i = 0; i < 6; i++) {
printf("--%d", times[i]);
}
printf("\n");
*/
}
if(temp == 2) {
count[1]++;
count[3]++;
times[change(b)+3]++;//甲乙赢使用的手势加一
}
if(temp == 3) {
count[2]++;
count[5]++;
}
}
for(int i = 0; i < 3; i++) {
if(times[i] > times[id1]) id1 = i;
if(times[i+3] > times[id2]) id2 = i;
}
printf("%d %d %d\n", count[0], count[2], count[1]);
printf("%d %d %d\n", count[3], count[5], count[4]);
printf("%c %c", str[id1], str[id2]);
return 0;
}
全部AC
#include<cstdio>
#include<iostream>
#include<cmath>
#include<cstring>
#include<string>
#include<ctime>
using namespace std;
int main()
{
int N;
scanf("%d",&N);
int Jy=0,Jp=0,Js=0;
int J[3]={0},Y[3]={0}; //B 0 C 1 J 2
char s1,s2;
for(int i=1;i<=N;i++){
getchar();
scanf("%c %c",&s1,&s2);
if(s1==s2) Jp++;
else if(s1=='C'&&s2=='J'){
Jy++;
J[1]++;
}else if(s1=='J'&&s2=='B'){
Jy++;
J[2]++;
}else if(s1=='B'&&s2=='C'){
Jy++;
J[0]++;
}else{
if(s2=='C') Y[1]++;
else if(s2=='J') Y[2]++;
else Y[0]++;
Js++;
}
}
printf("%d %d %d\n",Jy,Jp,Js);
printf("%d %d %d\n",Js,Jp,Jy);
if(J[0]>=J[1] && J[0]>=J[2]) printf("B ");
else if(J[1]>=J[2]) printf("C ");
else printf("J ");
if(Y[0]>=Y[1] && Y[0]>=Y[2]) printf("B");
else if(Y[1]>=Y[2]) printf("C");
else printf("J");
printf("\n");
return 0;
}
---------------------
作者:fengwuyaQAQ
来源:CSDN
原文:https://blog.csdn.net/fengwuyaQAQ/article/details/85616584
版权声明:本文为博主原创文章,转载请附上博文链接!
PAT B1018.锤子剪刀布(20)的更多相关文章
- PAT B1018 锤子剪刀布 (20 分)
大家应该都会玩“锤子剪刀布”的游戏:两人同时给出手势,胜负规则如图所示: 现给出两人的交锋记录,请统计双方的胜.平.负次数,并且给出双方分别出什么手势的胜算最大. 输入格式: 输入第 1 行给出正整数 ...
- PAT 1018. 锤子剪刀布 (20)
现给出两人的交锋记录,请统计双方的胜.平.负次数,并且给出双方分别出什么手势的胜算最大. 输入格式: 输入第1行给出正整数N(<=105),即双方交锋的次数.随后N行,每行给出一次交锋的信息,即 ...
- PAT 1018 锤子剪刀布(20)
1018 锤子剪刀布 (20)(20 分) 大家应该都会玩"锤子剪刀布"的游戏:两人同时给出手势,胜负规则如图所示: 现给出两人的交锋记录,请统计双方的胜.平.负次数,并且给出双方 ...
- B1018 锤子剪刀布 (20分)
B1018 锤子剪刀布 (20分) 大家应该都会玩"锤子剪刀布"的游戏:两人同时给出手势. 现给出两人的交锋记录,请统计双方的胜.平.负次数,并且给出双方分别出什么手势的胜算最大. ...
- PAT乙级 1018. 锤子剪刀布 (20)
1018. 锤子剪刀布 (20) 时间限制 100 ms 内存限制 65536 kB 代码长度限制 8000 B 判题程序 Standard 作者 CHEN, Yue 大家应该都会玩“锤子剪刀布”的游 ...
- 牛客网 PAT 算法历年真题 1008 : 锤子剪刀布 (20)
锤子剪刀布 (20) 时间限制 1000 ms 内存限制 32768 KB 代码长度限制 100 KB 判断程序 Standard (来自 小小) 题目描述 大家应该都会玩“锤子剪刀布”的游戏:现给出 ...
- 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 大家应该都会玩“锤子剪刀布”的游 ...
随机推荐
- Django从Models 10分钟建立一套RestfulApi
目录 Django从Models 10分钟建立一套RestfulApi Django从Models 10分钟定制一个Admin后台 简介 Django是一套完善而强大的web开发框架, 结合Djang ...
- Spring AOP潜入易懂的讲解
为什么会有面向切面编程(AOP),我们知道Java是一个面向对象(OOP)的语言,但它有一些弊端,比如当我们需要为多个不具有继承关系的对象引入一个公共行为,例如日志,权限验证,事务等功能时,只能在每个 ...
- RabbitMQ 简使用案例
第一步导入依赖 : <dependency> <groupId>com.rabbitmq</groupId> <artifactId>amqp-clie ...
- Cache As Ram
1. Why need Cache? Cache又称之为高速缓存,是为了弥补CPU和主存之间逐渐增大的速度上的差距 而被迫在两者之间加入的一个小的SRAM.现代处理器上通常都会有三级或者是四级缓存,这 ...
- QTcpSocket 发送数据的几种方法
1.QTcpSocket 继承于QAbstractSocket继承于QIODevice 2.QTcpSocket 提供的几种接收和发送数据方法 write ( const char *, qint64 ...
- [学习]sentinel中的DatatSource(一) ReadableDataSource
sentinel是今年阿里开源的高可用防护的流量管理框架. git地址:https://github.com/alibaba/Sentinel wiki:https://github.com/alib ...
- 前端知识点回顾之重点篇——ES6的Iterator和Generator
Iterator 迭代器是一种接口.是一种机制. 为各种不同的数据结构提供统一的访问机制.任何数据结构只要部署 Iterator 接口,就可以完成遍历操作(即依次处理该数据结构的所有成员). Iter ...
- redis数据类型及订阅操作
Redis数据类型详解 Redis键/值介绍 Redis key值是二进制安全的,这意味着可以用任何二进制序列作为key值,从形如“foo”的简单字符串到一个JPG文件的内容都可以.空字符串也是有效k ...
- 注解方式实现AOP编程
步骤: 1) 先引入aop相关jar文件 (aspectj aop优秀组件) spring-aop-3.2.5.RELEASE.jar [spring3.2源码] aopal ...
- Event事件与协程
1.Event事件 Event事件的作用: - 用来控制线程的执行. - 由一些线程去控制另一些线程. 2.进程池与线程池 1)什么是进程池与线程池? 进程池与线程池是用来控制当前程序允许创建(进程/ ...