运输宝物
Description
众所周知,“西瓜”是大名鼎鼎的江洋大盗。有一次他偷到了一批宝库。
这批宝物共有n个,他一共有k个箱子。他只能用这些箱子把这些宝物运出去,为了保证运输安全,他不会把两个以上的宝物装入同一个箱子(一个箱子只能装1个或者2个宝物)。这些宝物的大小分别是s(1)、s(2)、s(3)……s(n)。(题目给出的重量保证是非降序,即s(i-1)<=s(i) 对于任何i>1)。
装进宝物后,每个箱子的容量要大于或者等于所装的宝物大小之和。为了规格统一,这些箱子每个的容量要一致。为了降低运费,箱子的容量要尽可能小。“西瓜”想要知道,在能运走的情况下,箱子容量最小是多少。
Input
多组输入
先输入n和k (1≤n≤2·k≤100 000),n是宝物数量,k是箱子数量。
下一行输入空格分隔的n个整数, s1,s2,...,sn (1≤s1≤s2≤...≤sn≤1 000 000),代表这些宝物的重量。
Output
输出一个整数,代表这些箱子容量的最小值。
代码:
#include<iostream>
#include<cstdio>
#include<algorithm>
using namespace std;
int main()
{
int n,k;
while(scanf("%d%d",&n,&k)!=EOF)
{
long w[100005];
for(int i=1;i<=n;i++)
cin>>w[i];
sort(w+1,w+n+1);
long max=0;
for(int i=1;i<=n-k;i++)
{
if(max<w[i]+w[2*(n-k)-i+1])
max=w[i]+w[2*(n-k)-i+1];
}
if(w[n]>max)
max=w[n];
cout<<max<<endl;
}
return 0;
}