题目地址:http://acm.hdu.edu.cn/showproblem.php?pid=2039
著名出题人小Q每次比赛后都会写一份《赛题分析》,包含比赛概况、每题的参考算法以及一些统计数值。
对于一道题来说,小Q会统计最短的验题人代码长度(Shortest judge solution)以及赛内参赛队伍最短的AC代码长度(Shortest team solution)。
统计验题人代码长度比较容易,因为验题人最多也不会超过20
个。但是统计选手代码长度就不容易了,因为大赛区动辄三四百支队伍。
请写一个程序,帮助小Q统计最短代码长度。
Input
第一行包含一个正整数T(1≤T≤13),表示赛题数量。
每道题第一行包含两个整数n,m(2≤n≤20,0≤m≤500),分别表示验题人数量以及AC了该题的队伍数量。
第二行包含n个正整数a1,a2,…,an(50≤ai≤65536),依次表示每个验题人的代码字节数。
第三行包含m个正整数b1,b2,…,bn(50≤bi≤65536),依次表示每支AC队伍的代码字节数。若m=0
则该行为空行。
Output
对于第i(1≤i≤T)道题,输出三行,第一行输出Problem x:,其中x=i+1000。
第二行输出Shortest judge solution: y bytes.,其中y表示最短的验题人代码字节数。
第三行输出Shortest team solution: z bytes.,其中z
表示最短的选手代码字节数,若不存在请输出N/A。
注意:间隔都是一个空格。
Sample Input
2
3 2
3627 1460 5288
2365 2671
2 0
5510 7682
Sample Output
Problem 1001:
Shortest judge solution: 1460 bytes.
Shortest team solution: 2365 bytes.
Problem 1002:
Shortest judge solution: 5510 bytes.
Shortest team solution: N/A bytes.
思路:创建两个数组,一个来存验题人的代码字节数,一个来存每支AC队伍的代码字节数,再调用min函数来求出其中最少的字节数就OK。
#include<iostream>
#include<algorithm>
using namespace std;
int main() {
int T,n,m,a[100000],b[100000];
cin>>T;
for(int j=1; j<=T; j++) {
cin>>n>>m;
for(int i=0; i<n; i++) //验题人的代码字节数
cin>>a[i];
for(int i=0; i<m; i++) //每支AC队伍的代码字节数
cin>>b[i];
if(m==0) { //两个if对是否AC0的队伍进行分类
cout<<"Problem "<<1000+j<<":"<<endl;
cout<<"Shortest judge solution: "<<*(min_element(a,a+n))<<" bytes."<<endl;
cout<<"Shortest team solution: N/A bytes."<<endl;
}
if(m!=0) {
cout<<"Problem "<<1000+j<<":"<<endl;
cout<<"Shortest judge solution: "<<*(min_element(a,a+n))<<" bytes."<<endl;
cout<<"Shortest team solution: "<<*(min_element(b,b+m))<<" bytes."<<endl;
}
}
}