试题编号: | 202303-2 | |||||||||||||||||||||||||
试题名称: | 垦田计划 | |||||||||||||||||||||||||
时间限制: | 1.0s | |||||||||||||||||||||||||
内存限制: | 512.0MB | |||||||||||||||||||||||||
问题描述: | 问题描述顿顿总共选中了 𝑛 块区域准备开垦田地,由于各块区域大小不一,开垦所需时间也不尽相同。据估算,其中第 𝑖 块(1≤𝑖≤𝑛)区域的开垦耗时为 𝑡𝑖 天。这 𝑛 块区域可以同时开垦,所以总耗时 𝑡𝑇𝑜𝑡𝑎𝑙 取决于耗时最长的区域,即:𝑡𝑇𝑜𝑡𝑎𝑙=max{𝑡1,𝑡2,⋯,𝑡𝑛} 为了加快开垦进度,顿顿准备在部分区域投入额外资源来缩短开垦时间。具体来说:
现在顿顿手中共有 𝑚 单位资源可供使用,试计算开垦 𝑛 块区域最少需要多少天? 输入格式从标准输入读入数据。 输入共 𝑛+1 行。 输入的第一行包含空格分隔的三个正整数 𝑛、𝑚 和 𝑘,分别表示待开垦的区域总数、顿顿手上的资源数量和每块区域的最少开垦天数。 接下来 𝑛 行,每行包含空格分隔的两个正整数 𝑡𝑖 和 𝑐𝑖,分别表示第 𝑖 块区域开垦耗时和将耗时缩短 1 天所需资源数量。 输出格式输出到标准输出。 输出一个整数,表示开垦 𝑛 块区域的最少耗时。 样例输入1 Data 样例输出1 Data 样例解释如下表所示,投入 5 单位资源即可将总耗时缩短至 5 天。此时顿顿手中还剩余 4 单位资源,但无论如何安排,也无法使总耗时进一步缩短。
样例输入2 Data 样例输出2 Data 样例解释投入 20 单位资源,恰好可将所有区域开垦耗时均缩短为 𝑘=2 天;受限于 𝑘,剩余的 10 单位资源无法使耗时进一步缩短。 子任务70% 的测试数据满足:0<𝑛,𝑡𝑖,𝑐𝑖≤100 且 0<𝑚≤106; 全部的测试数据满足:0<𝑛,𝑡𝑖,𝑐𝑖≤105 且 0<𝑚≤109。 |
import java.io.*;
public class Main {
static PrintWriter out = new PrintWriter(new BufferedWriter(new OutputStreamWriter(System.out)));
static QuickInput in = new QuickInput();
public static void main(String[] args) throws IOException {
int n = in.nextInt();
int m=in.nextInt();
int k=in.nextInt();
int[] c=new int[n];
int[] cc=new int[(int)Math.pow(10,5)+1];
int maxt=0;
for(int i=0;i<n;i++){
int temp=in.nextInt();
c[i]=in.nextInt();
cc[temp]+=c[i];
maxt=Math.max(maxt,temp);
}
for(int i=maxt;i>=k;i--){
if(m>cc[i]){
if(i==k){
out.println(k);
break;
}
m-=cc[i];
cc[i-1]+=cc[i];
}else{
out.println(i);
break;
}
}
out.flush();
}
static class QuickInput {
StreamTokenizer input = new StreamTokenizer(new BufferedReader(new InputStreamReader(System.in)));
int nextInt() throws IOException {
input.nextToken();
return (int) input.nval;
}
}
}