CodeForces 377B—Preparing for the Contest(二分+贪心)

CodeForces 377B—Preparing for the Contest(二分+贪心)

大家好,又见面了,我是全栈君,祝每个程序员都可以多学几门语言。

C – Preparing for the Contest

Time Limit:2000MS     Memory Limit:262144KB     64bit IO Format:%I64d & %I64u

Submit
 
Status
 
Practice
 
CodeForces 377B

 

Description

Soon there will be held the world’s largest programming contest, but the testing system still has m bugs. The contest organizer, a well-known university, has no choice but to attract university students to fix all the bugs. The university has n students able to perform such work. The students realize that they are the only hope of the organizers, so they don’t want to work for free: the i-th student wants to getci ‘passes’ in his subjects (regardless of the volume of his work).

Bugs, like students, are not the same: every bug is characterized by complexity aj, and every student has the level of his abilities bi. Student i can fix a bug j only if the level of his abilities is not less than the complexity of the bug: bi ≥ aj, and he does it in one day. Otherwise, the bug will have to be fixed by another student. Of course, no student can work on a few bugs in one day. All bugs are not dependent on each other, so they can be corrected in any order, and different students can work simultaneously.

The university wants to fix all the bugs as quickly as possible, but giving the students the total of not more than s passes. Determine which students to use for that and come up with the schedule of work saying which student should fix which bug.

Input

The first line contains three space-separated integers: n, m and s (1 ≤ n, m ≤ 105, 0 ≤ s ≤ 109) — the number of students, the number of bugs in the system and the maximum number of passes the university is ready to give the students.

The next line contains m space-separated integers a1, a2, …, am (1 ≤ ai ≤ 109) — the bugs’ complexities.

The next line contains n space-separated integers b1, b2, …, bn (1 ≤ bi ≤ 109) — the levels of the students’ abilities.

The next line contains n space-separated integers c1, c2, …, cn (0 ≤ ci ≤ 109) — the numbers of the passes the students want to get for their help.

Output

If the university can’t correct all bugs print “NO“.

Otherwise, on the first line print “YES“, and on the next line print m space-separated integers: the i-th of these numbers should equal the number of the student who corrects the i-th bug in the optimal answer. The bugs should be corrected as quickly as possible (you must spend the minimum number of days), and the total given passes mustn’t exceed s. If there are multiple optimal answers, you can output any of them.

Sample Input

Input
3 4 9
1 3 1 2
2 1 3
4 3 6

Output
YES
2 3 2 3

Input
3 4 10
2 3 1 2
2 1 3
4 3 6

Output
YES
1 3 1 3

Input
3 4 9
2 3 1 2
2 1 3
4 3 6

Output
YES
3 3 2 3

Input
3 4 5
1 3 1 2
2 1 3
5 3 6

Output
NO

Hint

Consider the first sample.

The third student (with level 3) must fix the 2nd and 4th bugs (complexities 3 and 2 correspondingly) and the second student (with level 1) must fix the 1st and 3rd bugs (their complexity also equals 1). Fixing each bug takes one day for each student, so it takes 2 days to fix all bugs (the students can work in parallel).

The second student wants 3 passes for his assistance, the third student wants 6 passes. It meets the university’s capabilities as it is ready to give at most 9 passes.

题意给出m个bug,每一个bug有个复杂程度,有n个同学每一个同学有自己的能力值b,和想要的东西c,

假设雇佣第i个同学,那么能解决全部复杂程度小于等于b[i]的bug,每天一人仅仅能解决一个,学校要付出c,不论i攻克了几个bug

问,学校在付出不超过s,且最少的天数须要多少。

有两个限制,1.总和不能超过s,2.要求最少天数。

仅仅能限制一个,来求还有一个,假设求总和不能超过s,不好求,那么仅仅能求最少天数,二分枚举最少的天数,找出最小花费,得到最后的结果。

假设是时间为t,那么找出全部能力大于当前最大的bug的人,找出须要c最少的,使用优先队列维护,让找出的人工作t天,工作bug最大的t个,使得后面的bug能够找很多其它的人来修。

 

 

#include <cstdio>
#include <cstring>
#include <queue>
#include <algorithm>
using namespace std;
#define LL __int64
#define INF 0x3f3f3f3f
struct node
{
    LL b , c , i ;
//    bool operator < (const node &x) const {
//        return c > x.c ;
//    }
    friend bool operator< (node n1, node n2)    {        return n1.c > n2.c;    }
} p[200000] , q ;
priority_queue <node> que ;
struct node1
{
    LL i , a ;
} bug[200000];
bool cmp(node x,node y)
{
    return x.b > y.b ;
}
bool cmp1(node1 x,node1 y)
{
    return x.a > y.a ;
}
LL last[110000] , now[110000 ] , n , m ,s ;
LL f(LL t)
{
    while( !que.empty() ) que.pop();
    LL i = 0 , j = 0 , ans = 0 , k ;
    while(j < m)
    {
        while(i < n && p[i].b >= bug[j].a)
        {
            que.push( p[i] ) ;
            i++ ;
        }
        if( que.empty() )
            return s+1 ;
        q = que.top();
        que.pop();
        ans += q.c ;
        k = j+t ;
        while(j < m && j < k)
        {
            now[ bug[j].i ] = q.i ;
            j++ ;
        }
    }
    return ans ;
}
int main()
{
    LL i , j ;
    memset(last,-1,sizeof(last));
    scanf("%I64d %I64d %I64d", &n, &m, &s);
    for(i = 0 ; i < m ; i++)
    {
        scanf("%I64d", &bug[i].a);
        bug[i].i = i ;
    }
    sort(bug,bug+m,cmp1);
    for(i = 0 ; i < n ; i++)
    {
        scanf("%I64d", &p[i].b);
        p[i].i = i+1 ;
    }
    for(i = 0 ; i < n ; i++)
    {
        scanf("%I64d", &p[i].c);
    }
    sort(p,p+n,cmp);
    LL low = 1 , mid , high = m , min1 ;
    while( low <= high )
    {
        mid = (low+high)/2 ;
        min1 = f(mid);
        if( min1 <= s )
        {
            for(i = 0 ; i < m ; i++)
                last[i] = now[i] ;
            high = mid-1 ;
        }
        else
            low = mid+1 ;
    }
    if( last[0] == -1 )
        printf("NO\n");
    else
    {
        printf("YES\n");
        for(i = 0 ; i < m ; i++)
        {
            if(i == m)
                printf("%d\n", last[i]);
            else
                printf("%d ", last[i]);
        }
    }
    return 0;
}

 

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/118121.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • Pytest(13)命令行参数–tb的使用

    Pytest(13)命令行参数–tb的使用前言pytest使用命令行执行用例的时候,有些用例执行失败的时候,屏幕上会出现一大堆的报错内容,不方便快速查看是哪些用例失败。–tb=style参数可以设置报错的时候回溯打印内容,可以设置参

    2022年7月31日
    5
  • 过压保护(2)_过压保护值和欠压保护值

    过压保护(2)_过压保护值和欠压保护值http://www.elecfans.com/dianlutu/protect/2009102499242.html采用CW136构成的过压保护电路图中是采用CW136构成的过压保护电路,当电子设备

    2022年8月2日
    6
  • OPKG包管理系统详解!带你管理OpenWrt系统软件[通俗易懂]

    OPKG包管理系统详解!带你管理OpenWrt系统软件[通俗易懂]一、OPKG简介OPKG(Open/OpenWrtPackage)是一个轻量快速的软件包管理系统,是IPKG的克隆,目前已成为开源嵌入式系统领域的事实标准。OPKG常用于路由、交换机等嵌入式设备中,用来管理软件包的下载、安装、升级、卸载和查询等,并处理软件包的依赖关系。功能和桌面Linux操作系统Ubuntu中的apt-get、Redhat中的yum类似 OPK…

    2022年6月11日
    473
  • (OS 10038)在一个非套接字上尝试了一个操作 的解决办法[通俗易懂]

    在SVN的机器上,系统盘,剩余空间不足1G,经查看,是C:\ProgramFiles(x86)\ApacheSoftwareFoundation\Apache2.2\logs里面存在了很多(每天一个)很大(600M或6G的)日志文件,error-2015-07-31.logs删除后,不几天就会重新生成。打开error-2015-07-31.logs文件,发现,如下信息【(OS10

    2022年4月13日
    74
  • 数据库中间件—详解

    数据库中间件—详解一 业务场景 1 当一张表进行水平分库分表之后 可能会影响已有产品功能 同时想要进行多张分表的搜索结果数据聚合在一起 在 sql 上会比较麻烦 只能不断 join 而且如果不知道分表的表名 业务 sql 书写上无法做到 2 数据库搭建好了完善的集群后 由于复杂度的上升 主从主备 读写分离 故障切换 心跳检测都是很繁杂的 能不能有种解决方案 能简单解决上述的各类繁杂问题 等等 二 解决方案引进数据库中间件 例如 Cobar M

    2025年7月31日
    1
  • landsat8与sentinel2波段对比

    landsat8与sentinel2波段对比landsat8与sentinel2波段对比Landsat8波段对比哨兵2号,通常Landsat8OLI使用7、5、2或7、5、3,哨兵2号相对应的为12、8、2。Landsat7ETM+通常采用7、4、1。新的改变我们对Markdown编辑器进行了一些功能拓展与语法支持,除了标准的Markdown编辑器功能,我们增加了如下几点新功能,帮助你用它写博客:全新的界面设计,将会带来全新…

    2022年7月23日
    9

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号