因为有很多队已经克隆过了
所以在VJ上可以看到其他队伍的排名情况和交题记录
刚开始几分钟 就有队伍过了F题
果断看F题 确实是个水题
HDU6292 赛题分析
Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 512000/512000 K (Java/Others)
Total Submission(s): 1882 Accepted Submission(s): 869
Problem Description
著名出题人小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.
思路:
暴力寻找最小值即可
注意判断 m 输入为 0 时 不输出最小值 而是 N/A
(我因为少了一个句号没发现 而WA了好多发 还好队友大白也写了一遍就AC了)
代码
#include <stdio.h>
#include <iostream>
#include <string.h>
#include <algorithm>
#include <bits/stdc++.h>
#include <math.h>
using namespace std;
int main()
{
int t, n, m, x, y;
scanf("%d", &t);
for (int i = 1; i <= t; i++) {
scanf("%d%d", &n, &m);
printf("Problem %d:\n", 1000 + i);
scanf("%d", &x);
int minn = x;
for (int j = 1; j < n; j++) {
scanf("%d", &x);
minn = min(minn, x);
}
printf("Shortest judge solution: %d bytes.\n", minn);
if (m > 0) {
scanf("%d", &y);
int mi = y;
for (int k = 1; k < m; k++) {
scanf("%d", &y);
mi = min(mi, y);
}
printf("Shortest team solution: %d bytes.\n", mi);
} else {
printf("Shortest team solution: N/A bytes.\n");
}
}
return 0;
}
PS: 这里不用long long ,数据不算很大……
与此同时 Alone 看了K题
我没仔细看