一、题目:
大家应该都会玩“锤子剪刀布”的游戏:两人同时给出手势,胜负规则如图所示:

现给出两人的交锋记录,请统计双方的胜、平、负次数,并且给出双方分别出什么手势的胜算最大。
输入格式:
输入第 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 <iostream>
#include<vector>
#include <string>
using namespace std;
int play(string j, string y) {
//记录甲胜平0,胜1,输2
if (j == "C" && y == "B") { return 2; }
if (j == "C" && y == "C") { return 0; }
if (j == "C" && y == "J") { return 1; }
if (j == "J" && y == "B") { return 1; }
if (j == "J" && y == "C") { return 2; }
if (j == "J" && y == "J") { return 0; }
if (j == "B" && y == "B") { return 0; }
if (j == "B" && y == "C") { return 1; }
if (j == "B" && y == "J") { return 2; }
}
string sheng(vector<int> a) {
// 胜利时 xC yJ zB
int c = a[0];
int j = a[1];
int b = a[2];
if (b >= c && b >= j) {
return "B";
}
else if (c >= j && c > b) {
return "C";
}
else {
return "J";
}
}
int main() {
int n;
cin >> n;
//胜利时 0C 1J 2B
vector<int>jia = { 0,0,0 };
vector<int>yi = { 0,0,0 };
int ping = 0;
int jiasheng = 0;
int jiashu = 0;
for (int i = 0; i < n; i++) {
string j, y;
cin >> j >> y;
if (play(j, y) == 0) {
ping++;
}
else if (play(j, y) == 1) {
jiasheng++;
if (j == "C") {
jia[0]++;
}
if (j == "J") {
jia[1]++;
}if (j == "B") {
jia[2]++;
}
}
else if (play(j, y) == 2) {
jiashu++;
if (y == "C") {
yi[0]++;
}
if (y == "J") {
yi[1]++;
}if (j == "B") {
yi[2]++;
}
}
}
cout << jiasheng << " " << ping << " " << jiashu << endl;
cout << jiashu << " " << ping << " " << jiasheng << endl;
cout << sheng(jia) << " " << sheng(yi) << endl;
}
三、问题分析:
1.测试点1.2.4
输出B,C,J时:
| MAX | 输出 |
| B=C=J | B |
| B=C | B |
| B=J | B |
| B | B |
| C=J | C |
| C | C |
| J | J |
所以当B最大(或大于等于C/J)时,输出B,即可取等号;
当C最大(或大于等于J)时,输出C,可取等号;
其余情况都输出J;
2.测试点3.5不对,求助!!!

954

被折叠的 条评论
为什么被折叠?



