来总结一道非常经典的好题

这一道题是通过贪心实现的

首先看到这一题的时间复杂度

n<=100000

需要一个比较玄学的做法

我们先假设把题干改成这个样子

一圈n个车位

停在每个车位都有一定的代价

停m个车 可以相邻 求最小代价

那么这就是非常简单的贪心

可以每一次都取当前最小的车位来停

那么这个题只不过是增加了一个不能两两相邻的限制条件

我们可以想办法变成上一个题

如果我们有一个环是这样的

x

y     z

a

这四个数中最小的数是x

然而y+z<x+a

如果我们用普通的贪心肯定是先取到最小的x

那么这一道题得出的就不是正确答案

我们假如要删掉x 选y和z  需要怎么处理呢?

我们可以添加一个值y+z-x点

如果将这个点加到答案里面 就相当于对x进行了删除操作 并且选上了y和z

注:我们还要证明一下为什么去掉x后 如果选y就一定也要选z

y x z

如果我们之前选过了x(最小)  现在有更优的解需要删掉x

假如我们只选了y

没有选z

那么这是不成立的

因为如果只选了y 完全可以把y替换成x从而得出一个更小更优的答案

所以如果选了y

就一定也会选z

这一道题的实现方法 就是维护一个优先队列

我们先把所有的点入队

这样子就队列内部就自动维护从小到大排序了(堆实现的)

我们每一次取出最前的一个点(当前最小)

累加到ans上 并把当前点删除 把两边合并

也就是

再把当前点的值变为左+右-自己 就是刚才说的

作为一个新的点加入到优先队列里去

如此一来 既维护了答案最小 也维护了点两两不相邻

这是比较经典且有难度的一个题型 要好好掌握!

#include<bits/stdc++.h>
#define N 200010
#define pa pair<int,int>
using namespace std;
int n,m,a[N];
int L[N],R[N];
bool vis[N];
void del(int x)
{
vis[x]=;
R[L[x]]=R[x];
L[R[x]]=L[x];
}
int main()
{
int n,m;
scanf("%d%d",&n,&m);
priority_queue<pa,vector<pa>,greater<pa> >q;
for(int i=;i<=n;i++)
{
scanf("%d",&a[i]);
if(i==)
L[i]=n;
else
L[i]=i-;
if(i==n) R[i]=;
else R[i]=i+;
q.push(pa(a[i],i));//优先队列
}
int ans=;
while(m--){
while(vis[q.top().second])
q.pop();
int x=q.top().second;
q.pop();
ans+=a[x];
a[x]=a[L[x]]+a[R[x]]-a[x];
del(L[x]);del(R[x]);
q.push(pa(a[x],x));
}
cout<<ans; return ;
}

贪心 park的更多相关文章

  1. 【AT2434】JOI 公園 (JOI Park) 最短路+贪心

    题解 我的歪解 我首先想的是分治,我想二分肯定不行,因为它是没有单调性的. 我想了一下感觉它的大部分数据应该是有凸性的(例如\(y=x^2\)的函数图像),所以可以三分. 下面是我的三分代码(骗了不少 ...

  2. Uva11292--------------(The Dragon of Loowater)勇者斗恶龙 (排序后贪心)

    ---恢复内容开始--- 题目: Once upon a time, in the Kingdom of Loowater, a minor nuisance turned into a major ...

  3. [ACM_水题] UVA 11292 Dragon of Loowater [勇士斗恶龙 双数组排序 贪心]

    Once upon a time, in the Kingdom of Loowater, a minor nuisance turned into a major problem. The shor ...

  4. uva11292贪心基础题目

    C - 贪心 基础 Crawling in process... Crawling failed Time Limit:1000MS     Memory Limit:65536KB     64bi ...

  5. L贪心基础

    <span style="color:#330099;">/* L - 贪心 基础 Time Limit:1000MS Memory Limit:65536KB 64b ...

  6. UVA 11292 Dragon of Loowater(简单贪心)

    Problem C: The Dragon of Loowater Once upon a time, in the Kingdom of Loowater, a minor nuisance tur ...

  7. POJ 3154 Graveyard【多解,数论,贪心】

    Graveyard Time Limit: 2000MS   Memory Limit: 65536K Total Submissions: 1707   Accepted: 860   Specia ...

  8. Gym - 101670B Pond Cascade(CTU Open Contest 2017 贪心,二分)

    题目: The cascade of water slides has been installed in the park recently and it has to be tested. The ...

  9. UVA 11292-Dragon of Loowater (贪心)

    Once upon a time, in the Kingdom of Loowater, a minor nuisance turned into a major problem. The shor ...

随机推荐

  1. jps简介

    java虚拟机进程状态工具-jps 功能简介 列出指定机器上的虚拟机的进程状态 命令格式 jps [ options ] [ hostid ] 其中options选项可有 选项 作用描述 -q 只输出 ...

  2. 浅谈Python Django框架

    1.Django简介 Python下有多款不同的 Web 框架,Django是最有代表性的一种.许多成功的网站和APP都基于Django. Django是一个开源的Web应用框架,由Python写成. ...

  3. 为什么阿里代码规约要求避免使用 Apache BeanUtils 进行属性复制

    缘起 有一次开发过程中,刚好看到小伙伴在调用 set 方法,将数据库中查询出来的 Po 对象的属性拷贝到 Vo 对象中,类似这样: 可以看出,Po 和 Vo 两个类的字段绝大部分是一样的,我们一个个地 ...

  4. sci,ei,istp三大科技文献检索系统

    印刷版(SCI) 双月刊 ,500种 联机版(SciSearch) 周更新 ,600种 光盘版(带文摘)(SCICDE) 月更新 ,500种(同印刷版) 网络版(SCIExpanded) 周更新 ,6 ...

  5. SDOI2019热闹又尴尬的聚会

    P5361 [SDOI2019]热闹又尴尬的聚会 出题人用脚造数据系列 只要将\(p\)最大的只求出来,\(q\)直接随便rand就能过 真的是 我们说说怎么求最大的\(p\),这个玩意具有很明显的单 ...

  6. 爬虫工程师的unidbg入门教程

    现在很多的app使用了so加密,以后会越来越多.爬虫工程师可能会直接逆向app,看java代码,完成java层的算法破解,但是如果遇到so该怎么办呢?可能你会直接破解so,但是真的会有很多爬虫工程师会 ...

  7. Linux中找不到ifconfig命令的解决方法

    1.ifconfig命令是设置或显示网络接口的程序,可以显示出我们机器的网卡信息,可是有些时候最小化安装CentOS等Linux发行版的时候会默认不安装ifconfig等命令,这时候你进入终端,运行i ...

  8. 机器学习之——集成算法,随机森林,Bootsing,Adaboost,Staking,GBDT,XGboost

    集成学习 集成算法 随机森林(前身是bagging或者随机抽样)(并行算法) 提升算法(Boosting算法) GBDT(迭代决策树) (串行算法) Adaboost (串行算法) Stacking ...

  9. http、https、SSL、TLS的区别

    一.HTTP和HTTPS之间的区别 HTTP是一种协议,全称叫作:超文本传输协议(HTTP,HyperText Transfer Protocol),是互联网上应用最为广泛的一种网络协议.所有的WWW ...

  10. nginx和keeplive实现负载均衡高可用

    一. Keeplive服务介绍 Keeplive期初是专门为LVS设计的,专门用来监控LVS集群系统中各个服务节点的状态,后来又加入VRRP的功能,因此除了配合LVS服务以外,也可以作为其他服务(ng ...