7-3 谁是赢家
某电视台的娱乐节目有个表演评审环节,每次安排两位艺人表演,他们的胜负由观众投票和 3 名评委投票两部分共同决定。规则为:如果一位艺人的观众票数高,且得到至少 1 名评委的认可,该艺人就胜出;或艺人的观众票数低,但得到全部评委的认可,也可以胜出。节目保证投票的观众人数为奇数,所以不存在平票的情况。本题就请你用程序判断谁是赢家。
> 输入格式:
输入第一行给出 2 个不超过 1000 的正整数 Pa 和 Pb,分别是艺人 a 和艺人 b
得到的观众票数。题目保证这两个数字不相等。随后第二行给出 3 名评委的投票结果。数字 0 代表投票给 a,数字 1 代表投票给
b,其间以一个空格分隔。
> 输出格式:
按以下格式输出赢家:
The winner is x: P1 + P2 其中 x 是代表赢家的字母,P1 是赢家得到的观众票数,P2 是赢家得到的评委票数。
> 输入样例:
327 129 1 0 1
> 输出样例:
The winner is a: 327 + 1
#include<iostream>
#include<cstring>
#include<cmath>
using namespace std;
int main() {
int pa, pb;
int d[3] = { 0 };
while (cin >> pa >> pb)
{
string s;
int counta=0, countb=0,final=0,p=0;
for (int i = 0; i < 3; i++)
{
cin >> d[i];
if (d[i] == 0)
{
counta+=1;
}
if (d[i] == 1)
{
countb+=1;
}
}
if (pa > pb && counta>0)
{
s = "a";
p = pa;
final = counta;
}
if (counta == 3)
{
s = "a";
p = pa;
final = counta;
}
if (pb > pa && countb > 0)
{
s = "b";
p = pb;
final = countb;
}
if(countb==3)
{
s = "b";
p = pb;
final = countb;
}
cout << "The winner is " << s << ": " << p << " + " << final;
}
}
思路:使用另外的变量,分别保存赢家的观众投票数和评委投票。 考虑考虑所有的4种情况(先普通再特殊),最后输出赢家、赢家的观众投票数、赢家的评委投票数。