Description

有n个房间和n盏灯,你需要在每个房间里放入一盏灯。每盏灯都有一定功率,每间房间都需要不少于一定功率的灯泡才可以完全照亮。
你可以去附近的商店换新灯泡,商店里所有正整数功率的灯泡都有售。但由于背包空间有限,你至多只能换k个灯泡。
你需要找到一个合理的方案使得每个房间都被完全照亮,并在这个前提下使得总功率尽可能小。

Input

第一行两个整数n,k(1<=k<=n<=500000)。
第二行n个整数p[i](1<=p[i]<=10^9),表示你现有的灯泡的功率。
第三行n个整数w[i](1<=w[i]<=10^9),表示照亮每间房间所需要的最小功率。

Output

如果无法照亮每间房间,仅输出NIE。
否则输出最小的总功率。

Sample Input

6 2

12 1 7 5 2 10

1 4 11 4 7 5

Sample Output

33

HINT

解释:将2和10换成4和4。配对方案为1-1,4-4,4-4,5-5,7-7,11-12。

/*题面选最小。。。

Multiset+贪心可水,原理就是小的灯泡能用则用,不能用的保留,最后再用k次机会滑稽掉剩下的。再有剩余的可以把之前用的灯泡和房间差值变成0来减小。

这个堆+贪心啊,我承认我傻=-=。想了好久才明白。

首先对功率和房间从大到小排序,排完以后开始贪心。把符合当前房间条件的所有的灯泡都放进堆里(这个堆也保留之前房间剩余的),在里面选个最小的来提供给房间。但是!当这个堆里啥玩意都没有,即对于这个垃圾房间没有灯泡给它,我们就用一次换灯泡的机会,再给ans加上房间的需求,然后继续即可以。

然后我就方了,为什么不用改别的灯泡呢=-=,我这个蒟蒻百思不得其解=-=。因为我们使用这次机会以后,首先,对于以后的数据,扩大了可选择的范围(因为灯泡里接下来的最大值被保留了),其次由于不存在可以给这个房间提供的灯泡(因为有的之前给别的了,如果别的被替换,还是得使用一次机会)这次机会必须得用掉,然后对于某个可能被替换掉的灯泡,我相当于把它延后选择,即先把接下来可用灯泡都用掉,最后一定会多剩余一个灯泡(如果有小到没法用的自然剩余,要是较小的在某个房间可用,便会剩下一个大的)。

综上而言,这个贪心是正确的,因为它没有导致答案变大(使用最小),且保证了可解(保留剩下最大)。*/

 #include<cstdio>
#include<queue>
#include<algorithm>
using namespace std;
int n,k;
const int N=;
priority_queue<int > red;
priority_queue<int,vector<int>,greater<int> > q;
long long ans;
int p[N],w[N];
inline bool m_s(int a,int b){
return a>b;
}
int main(){
scanf("%d%d",&n,&k);
for(int i=;i<=n;i++) scanf("%d",p+i);
for(int i=;i<=n;i++) scanf("%d",w+i);
sort(p+,p++n,m_s);sort(w+,w+n+,m_s);
for(int i=,j=;i<=n;i++){
while(p[j]>=w[i]) q.push(p[j++]);
if(!q.empty()){
ans+=q.top();
red.push(q.top()-w[i]);q.pop();continue;
}
k--,ans+=w[i];
if(k<) {printf("NIE\n");return ;}
}
while(k--)ans-=red.top(),red.pop();
printf("%lld\n",ans);
}

bzoj3728: PA2014Final Zarowki的更多相关文章

  1. 【BZOJ3728】PA2014Final Zarowki 贪心

    [BZOJ3728]PA2014Final Zarowki Description 有n个房间和n盏灯,你需要在每个房间里放入一盏灯.每盏灯都有一定功率,每间房间都需要不少于一定功率的灯泡才可以完全照 ...

  2. bzoj 3728: PA2014Final Zarowki

    3728: PA2014Final Zarowki Description 有n个房间和n盏灯,你需要在每个房间里放入一盏灯.每盏灯都有一定功率,每间房间都需要不少于一定功率的灯泡才可以完全照亮.你可 ...

  3. bzoj AC倒序

    Search GO 说明:输入题号直接进入相应题目,如需搜索含数字的题目,请在关键词前加单引号 Problem ID Title Source AC Submit Y 1000 A+B Problem ...

  4. BZOJ3723 : PA2014Final Gra w podwajanie

    暴力搜索出所有可行的形状,可以发现本质不同的形状数只有6000个左右. 对于每个形状,它的大小不超过$8\times 8$,故可以按照右下角为原点重建坐标系,用一个unsigned long long ...

  5. BZOJ3726 : PA2014Final Wykladzina

    从上到下枚举下底边,维护$a[i]$表示$i$向上延伸多少距离里面没有坏点,$b[i]$表示$i$向上延伸多少距离里面最多只有1个坏点. 设$l0[i],r0[i]$表示以$a[i]$为最小值,往左往 ...

  6. BSOJ 2423 -- 【PA2014】Final Zarowki

    Description 有n个房间和n盏灯,你需要在每个房间里放入一盏灯.每盏灯都有一定功率,每间房间都需要不少于一定功率的灯泡才可以完全照亮.  你可以去附近的商店换新灯泡,商店里所有正整数功率的灯 ...

  7. BZOJ3724 PA2014Final Krolestwo(欧拉回路+构造)

    如果没有长度为偶数的限制,新建一个点向所有奇点连边,跑欧拉回路即可,显然此时一定存在欧拉回路,因为所有点度数都为偶数. 考虑长度为偶数的限制,将每个点拆成两个点放进一个二分图里,那么每条原图中的边在二 ...

  8. 【刷题】BZOJ 3724 PA2014Final Krolestwo

    Description 你有一个无向连通图,边的总数为偶数. 设图中有k个奇点(度数为奇数的点),你需要把它们配成k/2个点对(显然k被2整除).对于每个点对(u,v),你需要用一条长度为偶数(假设每 ...

  9. BZOJ[3728]PA2014 Final Zarowki

    有n个房间和n盏灯,你需要在每个房间里放入一盏灯.每盏灯都有一定功率,每间房间都需要不少于一定功率的灯泡才可以完全照亮. 你可以去附近的商店换新灯泡,商店里所有正整数功率的灯泡都有售.但由于背包空间有 ...

随机推荐

  1. 编译安装nginx却requires the PCRE library

    编译安装nginx需要pcre包,未安装会有如下提示: ./configure: error: the HTTP rewrite module requires the PCRE library. Y ...

  2. Kafka官方文档翻译——简介

    简介 Kafka擅长于做什么? 它被用于两大类应用: 在应用间构建实时的数据流通道 构建传输或处理数据流的实时流式应用 几个概念: Kafka以集群模式运行在1或多台服务器上 Kafka以topics ...

  3. sql with as 用法(转载)

    一.WITH AS的含义     WITH AS短语,也叫做子查询部分(subquery factoring),可以让你做很多事情,定义一个SQL片断,该SQL片断会被整个SQL语句所用到.有的时候, ...

  4. .net core web api + Autofac + EFCore 个人实践

    1.背景 去年时候,写过一篇<Vue2.0 + Element-UI + WebAPI实践:简易个人记账系统>,采用Asp.net Web API + Element-UI.当时主要是为了 ...

  5. php后台拼接输出table表格

    <?php header("Content-type:text/html;charset=utf-8"); $str=''; $str.='<table border= ...

  6. 使用flask开发网站后端

    Flask 是一个用于 Python 的微型网络开发框架,可以用于快速的搭建一个小型的网站. 我的搜索引擎:http://www.abelkhan.com 就是基于flask开发 一个flask的He ...

  7. php几行代码实现CSV格式文件输出

    //适用于不需要设置格式简单将数据导出的程序,多多指教...... $str .= 'pro_code'.','.'words'.'\n';//首先写入表格标题栏 foreach($is_error ...

  8. 7.modifier插件的自定义和使用

    1.在plugins下面创建一个文件 modifier.changeDate.php 编写: <?php function smarty_modifier_changeDate($utime,$ ...

  9. VMware中Mac OS中显示共享文件夹的方法

    在finder 偏好设置里的通用标签下,勾选  “已连接的服务器”

  10. java excel导出

    下面是jsp代码: <li class="btns"><input id="btnExport" class="btn btn-pr ...