ccfcsp202303-2 垦田计划

试题编号:202303-2
试题名称:垦田计划
时间限制:1.0s
内存限制:512.0MB
问题描述:

问题描述

顿顿总共选中了 𝑛 块区域准备开垦田地,由于各块区域大小不一,开垦所需时间也不尽相同。据估算,其中第 𝑖 块(1≤𝑖≤𝑛)区域的开垦耗时为 𝑡𝑖 天。这 𝑛 块区域可以同时开垦,所以总耗时 𝑡𝑇𝑜𝑡𝑎𝑙 取决于耗时最长的区域,即:𝑡𝑇𝑜𝑡𝑎𝑙=max{𝑡1,𝑡2,⋯,𝑡𝑛}

为了加快开垦进度,顿顿准备在部分区域投入额外资源来缩短开垦时间。具体来说:

  • 在第 𝑖 块区域投入 𝑐𝑖 单位资源,便可将其开垦耗时缩短 1 天;

  • 耗时缩短天数以整数记,即第 𝑖 块区域投入资源数量必须是 𝑐𝑖 的整数倍;

  • 在第 𝑖 块区域最多可投入 𝑐𝑖×(𝑡𝑖−𝑘) 单位资源,将其开垦耗时缩短为 𝑘 天;

  • 这里的 𝑘 表示开垦一块区域的最少天数,满足 0<𝑘≤min{𝑡1,𝑡2,⋯,𝑡𝑛};换言之,如果无限制地投入资源,所有区域都可以用 𝑘 天完成开垦。

现在顿顿手中共有 𝑚 单位资源可供使用,试计算开垦 𝑛 块区域最少需要多少天?

输入格式

从标准输入读入数据。

输入共 𝑛+1 行。

输入的第一行包含空格分隔的三个正整数 𝑛、𝑚 和 𝑘,分别表示待开垦的区域总数、顿顿手上的资源数量和每块区域的最少开垦天数。

接下来 𝑛 行,每行包含空格分隔的两个正整数 𝑡𝑖 和 𝑐𝑖,分别表示第 𝑖 块区域开垦耗时和将耗时缩短 1 天所需资源数量。

输出格式

输出到标准输出。

输出一个整数,表示开垦 𝑛 块区域的最少耗时。

样例输入1

4 9 2
6 1
5 1
6 2
7 1

Data

样例输出1

5

Data

样例解释

如下表所示,投入 5 单位资源即可将总耗时缩短至 5 天。此时顿顿手中还剩余 4 单位资源,但无论如何安排,也无法使总耗时进一步缩短。

𝑖基础耗时 𝑡𝑖缩减 1 天所需资源 𝑐𝑖投入资源数量实际耗时
16115
25105
36225
47125

样例输入2

4 30 2
6 1
5 1
6 2
7 1

Data

样例输出2

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


    }
}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值