什么是企业网站源码,住房和城乡建设部网站园林一级,手机网站怎么解析,做网站需要多少空间主要是想借这题巩固巩固c map的使用方法。
大家应该都会玩“锤子剪刀布”的游戏#xff1a;两人同时给出手势#xff0c;胜负规则如图所示#xff1a; 现给出两人的交锋记录#xff0c;请统计双方的胜、平、负次数#xff0c;并且给出双方分别出什么手势的胜算最大。
输…主要是想借这题巩固巩固c map的使用方法。
大家应该都会玩“锤子剪刀布”的游戏两人同时给出手势胜负规则如图所示 现给出两人的交锋记录请统计双方的胜、平、负次数并且给出双方分别出什么手势的胜算最大。
输入格式
输入第 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代码长度限制
16 KB
时间限制
200 ms
内存限制
64 MB
栈限制
8192 KB
我的思路
先算出甲的胜利平局失败乙的就和他相对了再分别将甲和乙的不同胜利方法放入不同的数组记忆下来然后再比较得到最大值接着利用map容器将不同数字对应到不同字母上去最后完成输出即可来看看代码
我的代码
#includeiostream
#includemap//map的头文件
using namespace std;
int main()
{int n;cin n;int a 0;int j 0;int jia[3] {0};int yi[3] {0};string o,p;//使用string类型的变量是为了躲避空格的输入但是这就像是你开了一个数组你得使用数组下标来访问由于只输入了一个字母所以[0]访问0就行了for(int i 0;i n;i){//将不同人的不同胜利结果存储到数组里面cin o p;if(o[0] p[0]){j;} else if(o[0] Bp[0]C){a;jia[0];} else if(o[0] Cp[0] J){a;jia[1];} else if(o[0] Jp[0] B){a;jia[2];} else if(p[0] Bo[0]C){yi[0];} else if(p[0] Co[0] J){yi[1];} else if(p[0] Jo[0] B){yi[2];}}cout a j n-a-j endl;//cout n-a-j j a endl;mapint,char s;//定义一个从int类型映射到char类型的容器s[0] B;//分别映射对其记得要按照字母的ASCII码的顺序映射s[1] C;s[2] J;int maxj 0,maxy 0;//分别找到甲乙最大值最后利用map容器映射输出就好了for(int i 1;i 3;i){if(jia[maxj] jia[i]){maxj i;}if(yi[maxy] yi[i]){maxy i;}}cout s[maxj] s[maxy];return 0;
}
学过的知识要记得复习呢。
到这里就结束啦
欢迎小伙伴们评论区讨论提问。
我是荒古前期待你的关注~~~
~~~完结撒花✌y( •̀ ω •́ )y✌~~~