全场最水题之陈兴老师与比赛

探讨了ACM比赛中如何优化做题顺序以减少总罚时,通过算法实现最佳解,介绍了输入输出格式及样例。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

全场最水题之陈兴老师与比赛

Time Limit: 1 Sec   Memory Limit: 128 MB
Submit: 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
****************************************************************/


评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值