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;
}