一个没有通过,不知道为何

#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)的更多相关文章

  1. PAT B1018 锤子剪刀布 (20 分)

    大家应该都会玩“锤子剪刀布”的游戏:两人同时给出手势,胜负规则如图所示: 现给出两人的交锋记录,请统计双方的胜.平.负次数,并且给出双方分别出什么手势的胜算最大. 输入格式: 输入第 1 行给出正整数 ...

  2. PAT 1018. 锤子剪刀布 (20)

    现给出两人的交锋记录,请统计双方的胜.平.负次数,并且给出双方分别出什么手势的胜算最大. 输入格式: 输入第1行给出正整数N(<=105),即双方交锋的次数.随后N行,每行给出一次交锋的信息,即 ...

  3. PAT 1018 锤子剪刀布(20)

    1018 锤子剪刀布 (20)(20 分) 大家应该都会玩"锤子剪刀布"的游戏:两人同时给出手势,胜负规则如图所示: 现给出两人的交锋记录,请统计双方的胜.平.负次数,并且给出双方 ...

  4. B1018 锤子剪刀布 (20分)

    B1018 锤子剪刀布 (20分) 大家应该都会玩"锤子剪刀布"的游戏:两人同时给出手势. 现给出两人的交锋记录,请统计双方的胜.平.负次数,并且给出双方分别出什么手势的胜算最大. ...

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

    1018. 锤子剪刀布 (20) 时间限制 100 ms 内存限制 65536 kB 代码长度限制 8000 B 判题程序 Standard 作者 CHEN, Yue 大家应该都会玩“锤子剪刀布”的游 ...

  6. 牛客网 PAT 算法历年真题 1008 : 锤子剪刀布 (20)

    锤子剪刀布 (20) 时间限制 1000 ms 内存限制 32768 KB 代码长度限制 100 KB 判断程序 Standard (来自 小小) 题目描述 大家应该都会玩“锤子剪刀布”的游戏:现给出 ...

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

    1018. 锤子剪刀布 (20) 时间限制 100 ms 内存限制 65536 kB 代码长度限制 8000 B 判题程序 Standard 作者 CHEN, Yue 大家应该都会玩“锤子剪刀布”的游 ...

  8. 【PAT】1018 锤子剪刀布 (20)(20 分)

    1018 锤子剪刀布 (20)(20 分) 大家应该都会玩“锤子剪刀布”的游戏:两人同时给出手势,胜负规则如图所示: 现给出两人的交锋记录,请统计双方的胜.平.负次数,并且给出双方分别出什么手势的胜算 ...

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

    1018. 锤子剪刀布 (20) 时间限制 100 ms 内存限制 65536 kB 代码长度限制 8000 B 判题程序 Standard 作者 CHEN, Yue 大家应该都会玩“锤子剪刀布”的游 ...

随机推荐

  1. codeforces#1183F. Topforces Strikes Back(数论)

    题目链接: http://codeforces.com/contest/1183/problem/F 题意: 给出n个数,找出最多三个互不整除的数,取最大的和 数据范围: $1 \le n \le 2 ...

  2. Mybatis源码学习之parsing包(解析器)(二)

    简述 大家都知道mybatis中,无论是配置文件mybatis-config.xml,还是SQL语句,都是写在XML文件中的,那么mybatis是如何解析这些XML文件呢?这就是本文将要学习的就是,m ...

  3. 锁对象Lock-同步问题更完美的处理方式

    Lock是java.util.concurrent.locks包下的接口,Lock 实现提供了比使用synchronized 方法和语句可获得的更广泛的锁定操作,它能以更优雅的方式处理线程同步问题,我 ...

  4. springboot内置分页技术

    1,在pom.xml中注入分页的配置 <dependency> <groupId>com.github.pagehelper</groupId> <artif ...

  5. SRCNN代码分析

    代码是作者页面上下载的matlab版.香港中文大学汤晓鸥教授.Learning a Deep Convolutional Network for Image Super-Resolution. htt ...

  6. Python3+RobotFramewok 循环判断以及Evaluate用法(三)

    本章主要介绍RF的循环,判断以及关键字Evaluate. 1. for循环 在RF中通过 :FOR 编写循环 :FOR ${i} in range 10 log ${i} @{list} create ...

  7. R语言与概率统计(五) 聚类分析

    #########################################0808聚类分析 X<-data.frame( x1=c(2959.19, 2459.77, 1495.63, ...

  8. sizeof和strlen函数区别

    一.sizeof    sizeof(...)是运算符,在头文件中typedef为unsigned int,其值在编译时即计算好了,参数可以是数组.指针.类型.对象.函数等.    它的功能是:获得保 ...

  9. nginx反向代理cookie相关

    http://blog.csdn.net/xiansky2015/article/details/51674997 http://www.jianshu.com/p/aeed2a56a3eb

  10. Java集合(0):概述

    下面是一个Java集合的简化图,我们可以看出,集合分Collection和Map两大部分: 接下来分别以下面几个章节介绍Java集合: Java集合(1):Collections工具类中的static ...