UVA 11729 Commando War

题目来源

Commando War

Description

你有 n 个部下, 每个部下需要完成一项任务。

第i个部下需要你花 Bi 分钟交代任务, 然后他会独立地、无间断地执行 Ji 分钟后完成任务。

你需要选择交代任务的顺序, 使得所有的任务尽早执行完毕(即最后一个执行完的任务应尽早结束)。

注意, 不能同时给两个部下交待任务, 但部下们可以同时执行他们各自的任务。

Input

输入包含多组数据, 每组数据阿德第一行为部下的个数 N (1 <= N <= 1 000)

以下 N 行每行两个正整数 B 和 J(1 <= B, J <= 10 000), 即交代任务的时间和执行任务所需时间。 输入结束标志: N = 0

Output

对于每组数据, 输出所有任务完成的最短时间。

SampleInput

3
2 5
3 2
2 1
3
3 3
4 4
5 5
0

SampleOutput

Case 1: 8
Case 2: 15

Analyze

我们首先应该确定执行时间长的应该首先交代。根据执行任务的时间 按照从小到大的顺序排序,然后依次交代。


Code

#include <cstdio>
#include <algorithm>
#include <iostream>
#include <cstring>
#include <fstream>
#include <map>
#include <queue>
#include <set>
#include <cstdlib>
#include <ctime>
#include <vector>
#include <cmath>
#include <limits.h>
using namespace std;

struct Job
{
    int j;  //执行任务时间
    int b;  //交代任务时间
    //执行任务时间长的排序在前面
    bool operator < (const Job& x) const{
        return j > x.j;
    }
};

int main()
{
    int n, b, j, Case=1;

    while(scanf("%d", &n) == 1 && n)
    {
        vector <Job> v;
        for(int i=0; i<n; i++)
        {
            scanf("%d%d", &b, &j);
            v.push_back((Job){j,b});
        }
        sort(v.begin(), v.end());   //按照执行任务从大到小排序。
        int s = 0;
        int ans = 0;
        for(int i=0; i<n; i++)
        {
            s += v[i].b;    //交待任务的时间
            ans = max(ans, s+v[i].j);   //执行完毕的最晚时间
        }
        printf("Case %d: %d\n", Case++, ans);
    }

    return 0;
}
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值