Description
现举行一次小竞赛,参赛的3支队伍,编号为1、2、3。每支队列轮流回答问题,如果回答正确加10分;回答错误扣10分;放弃回答不得分。经过多轮答题后,我们要统计各队的名次和得分。
每支队伍参加比赛的初始分数都是0分,经过多轮答题后,分数可能为负分。
Main Goal:
结构体练习
Input
第一行为回答问题的轮次数n。
其余各行分别为1、2、3号队伍答题的结果,回答正确为right,错误为wrong,放弃为give-up。
Output
参照示例按名次输出各队的编号和得分,每个括号中代表一个队伍的得分情况,第一个数表示队伍编号,第二个数表示队伍得分,两个数字中间用逗号分开。
名次相同队伍得分情况的在同一行输出,且编号小者靠前,两个队伍的括号之间不要有空格。
Sample Input
4
right wrong give-up
right right right
wrong right right
right right right
Sample Output
(3,30)
(1,20)(2,20)
Source1
#include<stdio.h>
typedef struct zu
{
int num;
int score;
}ZU;
int main(){
int n;
ZU z[3]={{1,0},{2,0},{3,0}};
ZU s;
char t[100];
int i,j;
scanf("%d",&n);
for(i=0;i<n;i++){
for(j=0;j<3;j++){
scanf("%s",&t);
if(t[0]=='r') z[j].score+=10;
else if(t[0]=='w') z[j].score-=10;
}
}
for(i=0;i<2;i++){
for(j=i;j<3;j++){
if(z[i].score<z[j].score){
s=z[j];
z[j]=z[i];
z[i]=s;
}
}
}
for(i=0;i<2;i++){
for(j=i;j<3;j++){
if((z[i].score==z[j].score)&&(z[i].num>z[j].num)){
s=z[j];
z[j]=z[i];
z[i]=s;
}
}
}
printf("(%d,%d)",z[0].num,z[0].score);
if(z[0].score>z[1].score) printf("\n");
printf("(%d,%d)",z[1].num,z[1].score);
if(z[1].score>z[2].score) printf("\n");
printf("(%d,%d)\n",z[2].num,z[2].score);
}
2:
#include<stdio.h>
struct dui{
int bianhao;
int fenshu;
};
int main(){
int n,i,j;
struct dui a[4],c;
char b[20];
scanf("%d",&n);
for(i=0;i<3;i++){
a[i].fenshu=0;
a[i].bianhao=i+1;
}
while(n--){
for(i=0;i<3;i++){
scanf("%s",&b);
if(b[0]=='r') a[i].fenshu+=10;
else if(b[0]=='w') a[i].fenshu-=10;
}
}
for(i=0;i<2;i++){
for(j=1;j<3;j++){
if(a[i].fenshu<a[j].fenshu){
c=a[i];
a[i]=a[j];
a[j]=c;
}
if(a[i].fenshu==a[j].fenshu && a[i].bianhao>a[j].bianhao){
c=a[i];
a[i]=a[j];
a[j]=c;
}
}
}
printf("(%d,%d)",a[0].bianhao,a[0].fenshu);
for(i=1;i<3;i++){
if(a[i].fenshu!=a[i-1].fenshu) printf("\n");
printf("(%d,%d)",a[i].bianhao,a[i].fenshu);
}
}
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。
文章由极客之音整理,本文链接:https://www.bmabk.com/index.php/post/69381.html