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 编程团体赛的文章就介绍到这儿,希望我们推荐的文章对大家有所帮助,也希望大家多多支持为之网!
- 2024-11-26Mybatis官方生成器资料详解与应用教程
- 2024-11-26Mybatis一级缓存资料详解与实战教程
- 2024-11-26Mybatis一级缓存资料详解:新手快速入门
- 2024-11-26SpringBoot3+JDK17搭建后端资料详尽教程
- 2024-11-26Springboot单体架构搭建资料:新手入门教程
- 2024-11-26Springboot单体架构搭建资料详解与实战教程
- 2024-11-26Springboot框架资料:新手入门教程
- 2024-11-26Springboot企业级开发资料入门教程
- 2024-11-26SpringBoot企业级开发资料详解与实战教程
- 2024-11-26Springboot微服务资料:新手入门全攻略