正题

题目链接:https://www.luogu.com.cn/problem/P7990


题目大意

数轴上有\(k\)个点是草地,每个草地有不同收益,\(m\)个点是地方的点,现在你要放置\(n\)个我方的点,不能和敌方的点重合。

如果一个草地离最近的我方的点距离严格小于最近的敌方点距离,那么这个草地被占领。

给出敌方点和草地坐标(保证两两不同),求占领草地的最大收益和 。

\(1\leq n,m,k\leq 2\times10^5,1\leq x\leq 10^9\)


解题思路

考虑在两个敌方点之间我们最多放两个己方点,又因为敌方点肯定和草地不重合所以放两个肯定能占领这之间的所有草地。

而且不能放敌方点的限制可以无视因为放敌方点没有任何收益。

然后我们再考虑如何算出两个敌方点之间放一个我方点的最大收益。

显然之间考虑位置很麻烦,我们可以考虑对于一个草地作为最右边的草地,那么一头牛能占领的最左边的草地,这个可以直接用一个双指针维护。

这样我们就得出了每一段放一头/两头牛的收益,记为\(c_{i,1/2}\)。

此时我们考虑暴力贪心开始把所有的\(c_{i,1}\)放进堆里,每次取出的如果是一个\(c_{i,1}\)那么把\(c_{i,2}-c_{i,1}\)再放进堆里做\(n\)次就可以了。

看起来这个贪心好像是错的,因为如果\(c_{i,2}\)远大于\(c_{i,1}\)时我们就可能牺牲第一次取小的来取第二次的。

但是实际上我们用在上面那个过程中不难发现,肯定是有\(c_{i,1}\geq c_{i,2}-c_{i,1}\)的(因为直接放在左右地方牛的旁边贡献大的那个位置就至少有一半的收益)。

时间复杂度:\(O(n\log n)\)

当然我推荐的做法是无脑wqs二分+dp


code

#include<cstdio>
#include<cstring>
#include<algorithm>
#include<queue>
#define ll long long
#define mp(x,y) make_pair(x,y)
using namespace std;
const ll N=2e5+10;
struct node{
ll p,t;
}a[N];
ll n,m,k,ans,s[N],f[N],w[N],v[N];
priority_queue<pair<ll,ll> > q;
bool cmp(node x,node y)
{return x.p<y.p;}
signed main()
{
scanf("%lld%lld%lld",&k,&m,&n);
for(ll i=1;i<=k;i++)
scanf("%lld%lld",&a[i].p,&a[i].t);
for(ll i=1;i<=m;i++)scanf("%lld",&f[i]);
sort(a+1,a+1+k,cmp);
sort(f+1,f+1+m);f[0]=-1e9;f[m+1]=2e9;
ll now=1,l=1,las=0,maxs=0;
for(ll i=1;i<=k;i++){
s[i]=s[i-1]+a[i].t;
while(l<=m&&f[l]<a[i].p){
w[l]=maxs;v[l]=s[i-1]-s[las];
las=i-1;now=i;maxs=0;l++;
}
ll L=f[l-1],R=f[l];
while((a[i].p-a[now].p)*2>=R-L)now++;
maxs=max(maxs,s[i]-s[now-1]);
}
w[l]=maxs;v[l]=s[n]-s[las];
for(ll i=0;i<=k+1;i++)
q.push(mp(w[i],i));
for(ll i=1;i<=n;i++){
pair<ll,ll> w=q.top();
ans+=w.first;q.pop();
if(w.second)q.push(mp(v[w.second]-w.first,0));
}
printf("%lld\n",ans);
return 0;
}

P7990-[USACO21DEC]Closest Cow Wins S【堆,贪心】的更多相关文章

  1. [USACO12FEB]牛券Cow Coupons(堆,贪心)

    [USACO12FEB]牛券Cow Coupons(堆,贪心) 题目描述 Farmer John needs new cows! There are N cows for sale (1 <= ...

  2. BZOJ_2802_[Poi2012]Warehouse Store_堆+贪心

    BZOJ_2802_[Poi2012]Warehouse Store_堆+贪心 Description 有一家专卖一种商品的店,考虑连续的n天. 第i天上午会进货Ai件商品,中午的时候会有顾客需要购买 ...

  3. BZOJ_1150_[CTSC2007]数据备份Backup_堆+贪心

    BZOJ_1150_[CTSC2007]数据备份Backup_堆+贪心 Description 你在一家 IT 公司为大型写字楼或办公楼(offices)的计算机数据做备份.然而数据备份的工作是枯燥乏 ...

  4. poj3045 Cow Acrobats (思维,贪心)

    题目: poj3045 Cow Acrobats 解析: 贪心题,类似于国王游戏 考虑两个相邻的牛\(i\),\(j\) 设他们上面的牛的重量一共为\(sum\) 把\(i\)放在上面,危险值分别为\ ...

  5. P4053 [JSOI2007]建筑抢修 堆贪心

    思路:堆贪心 提交:1次 题解: 先按时间\(sort\),然后如果能修就直接扔堆里,不能修取堆顶比一下时间长短,把时间短的扔进堆: #include<cstdio> #include&l ...

  6. HDU5124lines题解-堆+贪心的一个新方法

    题目链接 https://cn.vjudge.net/problem/HDU-5124 胡扯 感觉说新方法好像有点不太好,但是翻了十几篇博客都是清一色离散化之类的... 为什么会做这道题呢?因为前几天 ...

  7. 洛谷P1484 种树&洛谷P3620 [APIO/CTSC 2007]数据备份 题解(堆+贪心)

    洛谷P1484 种树&洛谷P3620 [APIO/CTSC 2007]数据备份 题解(堆+贪心) 标签:题解 阅读体验:https://zybuluo.com/Junlier/note/132 ...

  8. 【BZOJ1623】 [Usaco2008 Open]Cow Cars 奶牛飞车 贪心

    SB贪心,一开始还想着用二分,看了眼黄学长的blog,发现自己SB了... 最小道路=已选取的奶牛/道路总数. #include <iostream> #include <cstdi ...

  9. BZOJ 1029: [JSOI2007]建筑抢修 堆+贪心

    1029: [JSOI2007]建筑抢修 Description 小刚在玩JSOI提供的一个称之为“建筑抢修”的电脑游戏:经过了一场激烈的战斗,T部落消灭了所有z部落的入侵者.但是T部落的基地里已经有 ...

随机推荐

  1. fastq文件基本信息统计工具

    之前写的一个小工具,写的很简陋,名字取的也很随意就叫skr,哈哈.主要是fq转fa.合并多个染色体的vcf文件等,功能不多(主要是C写起来太操蛋了T_T),通常我也只用来统计fastq文件信息: 这里 ...

  2. linux 线程函数小结

    由于主线程已经开始跑了,次线程还在使用串口打印需要一点时间,因此打印的都是重复的. #include "pthread.h" #include "stdio.h" ...

  3. Linux-各种姿势(less\vi等)打开各种类型的文件(txt/csv/xlsx等)出现不能打开(全乱码、部分乱码、二进制文件等)的问题

    (一)linux各种中文乱码解决办法整理 远程登录服务器用vim在终端下编辑查看文件经常会遇见各种中文乱码问题. 做如下设置可基本解决vim中文乱码问题,首先查看系统对中文的支持locale -a | ...

  4. socket编程:多路复用I/O服务端客户端之select

    其实在之前的TCP之中,我们编程实现了多进程,多线程机制下的TCP服务器,但是对于这种的TCP服务器而言,存在太大的资源局限性.所以我们可以是用I/0模型中的多路复用I/O模型来进行编程. 他的具体思 ...

  5. 一款真正可以拿的出手的本土嵌入式RTOS-SylixOS

    由 winniewei 提交于 周四, 12/20/2018 作者:张国斌 在参加工信部人才交流中心和南京浦口区开发区管委会联合举办的第三届集成电路产业紧缺人才创新发展高级研修班暨产业促进交流会期间, ...

  6. java类加载、对象创建过程

    类加载过程: 1, JVM会先去方法区中找有没有相应类的.class存在.如果有,就直接使用:如果没有,则把相关类的.class加载到方法区 2, 在.class加载到方法区时,会分为两部分加载:先加 ...

  7. Leetcode中的SQL题目练习(一)

    595. Big Countries https://leetcode.com/problems/big-countries/description/ Description name contine ...

  8. Oracle中的null与空字符串''的区别

    含义解释:问:什么是NULL?答:在我们不知道具体有什么数据的时候,也即未知,可以用NULL,我们称它为空,ORACLE中,含有空值的表列长度为零.ORACLE允许任何一种数据类型的字段为空,除了以下 ...

  9. MySQL(2):数据管理

    一. 外键概念: 如果公共关键字在一个关系中是主关键字,那么这个公共关键字被称为另一个关系的外键.由此可见,外键表示了两个关系之间的相关联系.以另一个关系的外键作主关键字的表被称为主表,具有此外键的表 ...

  10. 【Services】【Web】【tomcat】配置tomcat支持https传输

    1. 基础: 1.1. 描述:内网的tomcat接到外网nginx转发过来的请求之后需要和外网的客户端进行通讯,为了保证通讯内容的安装,使用tomcat使用https协议. 1.2. 链接:http: ...