全场最水题之陈兴老师与比赛
Time Limit: 1 Sec Memory Limit: 128 MBSubmit: 401 Solved: 151
[ Submit][ Status][ Web Board]
Description
大家都知道ACM比赛罚时很重要。比如说你做A题要10分钟,B题要15分钟,如果先做A题再做B题,那么在ranking上的时间就是10 + (10)+ 15 = 35。如果先做B题再做A题总罚时就是15+(15)+
10=40.现在陈兴老师要做一场比赛,比赛有n道题, 总时间是300分钟。我们的陈兴老师仅仅看题目就可以知道他做每道题需要的时间。比如一般的比赛,陈兴老师做第一题需要1分钟,第二题2分钟,依此类推,陈兴老师只需要66分钟就可以AK一场11道题的比赛。PS: 陈兴老师做题都是1Y,膜拜陈兴老师Orz!
Input
第一行是一个数字n 0<n<=25
第二行是n个数字,第i个数字代表陈兴老师出编号为i的题所需要的时间 ti( 0 < ti <= 80)。
Output
第一行输出陈兴老师的出题数和Penalty(总时间)
以下按照顺序输出陈兴老师出题的顺序,每行一个编号。(详见输出样例)PS:时间一样的按编号升序输出。
Sample Input
31 2 341 2 3 4660 60 60 60 60 60
Sample Output
3 101234 2012345 90012345
#include<algorithm>
#include<cstdio>
#include<cstring>
#include<string>
#include<functional>
#include<iostream>
#include<vector>
using namespace std;
struct node
{
int num,time;
}a[30];
int cmp(node a,node b)
{
if(a.time==b.time)
{
return a.num<b.num;
}
else
{
return a.time<b.time;
}
}
int main()
{
int n,ans,flag,sum;
int i,j,k;
while(scanf("%d",&n)!=EOF)
{
ans=0;
sum=0;
flag=0;
for(i=0;i<n;i++)
{
scanf("%d",&a[i].time);
a[i].num=i+1;
}
sort(a,a+n,cmp);
for(i=0;i<n;i++)
{
sum+=a[i].time;
if(sum<=300)
{
ans=0;
for(j=0;j<=i;j++)
{
ans+=a[j].time*(i-j+1);
}
flag++;
}
}
printf("%d %d\n",flag,ans);
for(i=0;i<flag;i++)
{
printf("%d\n",a[i].num);
}
}
return 0;
}
/**************************************************************
Problem: 1315
User: 625524324
Language: C++
Result: Accepted
Time:4 ms
Memory:1484 kb
****************************************************************/