• 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
    ");
        else
        {
            printf("YES
    ");
            for(i = 0 ; i < m ; i++)
            {
                if(i == m)
                    printf("%d
    ", last[i]);
                else
                    printf("%d ", last[i]);
            }
        }
        return 0;
    }
    


     

  • 相关阅读:
    安猪瀚的一家之言:多读书,多看报,少吃零食,多睡觉
    关于概率分布理论的原理分析的一些讨论,以及经典概率分布的应用场景,以及概率统计其在工程实践中的应用
    从NLP任务中文本向量的降维问题,引出LSH(Locality Sensitive Hash 局部敏感哈希)算法及其思想的讨论
    代价敏感学习初探
    从矩阵(matrix)角度讨论PCA(Principal Component Analysis 主成分分析)、SVD(Singular Value Decomposition 奇异值分解)相关原理
    简要介绍Active Learning(主动学习)思想框架,以及从IF(isolation forest)衍生出来的算法:FBIF(Feedback-Guided Anomaly Discovery)
    线性方程组数学原理、矩阵原理及矩阵变换本质、机器学习模型参数求解相关原理讨论
    SpringMVC(十五):Dispatcher的重要组件之一MultipartResolver(StandardServletMultipartResolver和CommonsMultipartResolver)的用法
    SpringBoot(十八):SpringBoot2.1.1引入SwaggerUI工具
    SpringBoot(十七):SpringBoot2.1.1数据类型转化器Converter
  • 原文地址:https://www.cnblogs.com/yxwkf/p/4070591.html
Copyright © 2020-2023  润新知