1047 编程团体赛

2021/7/10 11:06:33

本文主要是介绍1047 编程团体赛,对大家解决编程问题具有一定的参考价值,需要的程序猿们随着小编来一起学习吧!

047 编程团体赛 (20分)

编程团体赛的规则为:每个参赛队由若干队员组成;所有队员独立比赛;参赛队的成绩为所有队员的成绩和;成绩最高的队获胜。

现给定所有队员的比赛成绩,请你编写程序找出冠军队。

输入格式:

输入第一行给出一个正整数 N(≤104
,即所有参赛队员总数。随后 N 行,每行给出一位队员的成绩,格式为:队伍编号-队员编号成绩,其中队伍编号为 1 到 1000 的正整数,队员编号为 1 到 10 的正整数,成绩为 0 到 100 的整数。

输出格式:
在一行中输出冠军队的编号和总成绩,其间以一个空格分隔。注意:题目保证冠军队是唯一的。

输入样例:

3-10 99
11-5 87
102-1 0
102-3 100
11-9 89
3-2 61
输出样例:

11 176

#include"stdio.h"//参考代码
int main(){
    int n,x,y,a[10000],b[1000]={0},flag=0,flag1=0;
    int i;
    scanf("%d",&n);
    for(i=0;i<n;i++){
        scanf("%d-%d %d",&x,&y,&a[i]);//我总是会卡住输入数据的设置上,可以不用设置那么多数组

        b[x]=b[x]+a[i];//直接把成绩储存到队伍中去了
    }
    for(i=0;i<1000;i++){
        if(flag<b[i]){//比大小
            flag=b[i];
            flag1=i;
        }
    }
    printf("%d %d",flag1,flag);
    return 0;
}

我的代码

#include<iostream>
#include<bits/stdc++.h>
using namespace std;
int main(){
    int n; 
    int duiwu[1000],duiyuan[1000];
    int grade[1000];
    int sum=0;
    cin>>n;
    for(int  ){
        for(int i=0;i<n;i++){
        cin>>duiwu[i]>>duiyuan[i]>>grade[i];
         for(int j=0;j<n;j++)    
        if(i!=j&&duiwu[i]==duiwu[j]&&sum<grade[i]+grade[j]) sum=grade[i]+grade[j];
        //cout<<sum;
            }
    }
    cout<<sum;
    return 0;
}

ps:

题目很简单,但是可以考虑怎么简化。

另外,scanf和printf格式化输入输出比cin.cout设置格式简单(个人感觉。)(来自某答主)



这篇关于1047 编程团体赛的文章就介绍到这儿,希望我们推荐的文章对大家有所帮助,也希望大家多多支持为之网!


扫一扫关注最新编程教程