1. 程式人生 > 實用技巧 >1018 錘子剪刀布 (20分)

1018 錘子剪刀布 (20分)

1018 錘子剪刀布 (20分)

大家應該都會玩“錘子剪刀布”的遊戲:兩人同時給出手勢,勝負規則如圖所示:

現給出兩人的交鋒記錄,請統計雙方的勝、平、負次數,並且給出雙方分別出什麼手勢的勝算最大。

輸入格式:

輸入第 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 main()
{
int a[26]={0};
int b[26]={0};
int jiaying=0,jiaping=0,jiafu=0;
char f1,f2;
int n;
scanf("%d",&n);
while(n--)
{
scanf(" %c %c",&f1,&f2);
if(f1==f2)
{
jiaping++;
}
else
{
if(f1=='C')
{
if(f2=='J')
{
jiaying++;
a[f1-'A']++;
}
else
{
jiafu++;
b[f2-'A']++;
}
}
else
if(f1=='J')
{
if(f2=='C')
{
jiafu++;
b[f2-'A']++;
}
else
{
jiaying++;
a[f1-'A']++;
}
}
else
if(f1=='B')
{
if(f2=='C')
{
jiaying++;
a[f1-'A']++;
}
else
{
jiafu++;
b[f2-'A']++;
}
}


}
}
int i;
int win_jia=1;
for(i=2;i<26;i++)
{
if(a[i]>a[win_jia])
{
win_jia=i;
}
}
int win_yi=1;
for(i=2;i<26;i++)
{
if(b[i]>b[win_yi])
{
win_yi=i;
}
}
printf("%d %d %d\n",jiaying,jiaping,jiafu);
printf("%d %d %d\n",jiafu,jiaping,jiaying);
printf("%c %c\n",win_jia+'A',win_yi+'A');


return 0;
}