【BZOJ 1150】[CTSC2007]数据备份Backup
【链接】 我是链接,点我呀:)
【题意】
在这里输入题意
【题解】
选择的连接肯定是相邻的点对。
那么我们处理出来长度为n-1的数组a
其中a[i-1] = dis[i]-dis[i-1]
那么问题就转化成在a数组中取出不相邻的k个数字。
这k个数字的和要求最小。
那么我们把每个数字都加入到堆中去。
然后对于k个数字。
每次取出堆中的最小值x
累加答案
但是这样做可能不是正确的。
因为可能选择x-1,x+1这两个点比单独选择一个点来得更优一些。
(如果你发现选x不是最优的->不选x->那么肯定吧x-1和x+1都选了更好
因此我们得给程序一个"反悔"的机会。
怎么给呢?
我们可以把x-1,x+1两个点的权值和减去x的权值和->temp。
然后加入到堆中去。
然后把x-1,x+1这两个点删掉。
x这个点的权值设置为刚才提到的temp
(这里要注意的一个思想就是,把x-1,x,x+1看成是一个整体,
这样下次如果再选这个x,就表示x不选了而把x-1,x+1选上。
->累加答案
这时仍然把x看成是一个点。
把它左边(此时是x-2)右边(x+2)的点删掉.
然后把a[x-2]+a[x+2]-a[x]再加入到堆中
重复上述步骤就好了
(这个时候-a[x]其实就是把那个"整体"里面选的变成不选,不选的变成选的了
(只有这样,x-2和x+2才能够被选中
(而且x这个整体里面会发现选中的点的个数总是比没选中的点个数多恰好1,所以再把x-2,x+2加上,刚好只会增加一个选择的点
我们每一次取出答案。
其实都只会让选中的点的个数递增1
所以堆中的每个元素其实对应的是,再多选一个点的话。
增加的代价是多少。
而我们每次选的都是最小的代价。
因此贪心的策略是正确的。
【代码】
/**************************************************************
Problem: 1150
User: chengchunyang
Language: C++
Result: Accepted
Time:696 ms
Memory:5260 kb
****************************************************************/
#include <bits/stdc++.h>
#define ll long long
using namespace std;
const int N = 1e5;
const int INF = 1e9+10;
int n,k;
int dis[N+10],a[N+10],L[N+10],R[N+10];
priority_queue<pair<ll,int>,vector<pair<ll,int> >,greater<pair<ll,int> > >pq;
bool vis[N+10];
int main()
{
scanf("%d%d",&n,&k);
for (int i = 1;i <= n;i++) scanf("%d",&dis[i]);
for (int i = 2;i <= n;i++) a[i-1] = dis[i]-dis[i-1];
n--;
a[0] = INF,a[n+1] = INF;
for (int i = 0;i <= n+1;i++) L[i] = i-1,R[i] = i+1;
for (int i = 1;i <= n;i++) pq.push(make_pair(a[i],i));
ll ans = 0;
for (int i = 1;i <= k;i++){
pair<ll,int> x;
do{
x = pq.top();pq.pop();
}while (vis[x.second]);
int id = x.second;
ans+=a[id];
a[id] = a[L[id]]+a[R[id]]-a[id];
pq.push(make_pair(a[id],id));
vis[L[id]] = vis[R[id]] = 1;
R[L[L[id]]] = id;
L[R[R[id]]] = id;
L[id] = L[L[id]];
R[id] = R[R[id]];
}
printf("%lld\n",ans);
return 0;
}
【BZOJ 1150】[CTSC2007]数据备份Backup的更多相关文章
- 【链表】bzoj 1150: [CTSC2007]数据备份Backup
1150: [CTSC2007]数据备份Backup Time Limit: 10 Sec Memory Limit: 162 MBSubmit: 1136 Solved: 458[Submit] ...
- [BZOJ 1150] [CTSC2007] 数据备份Backup 【贪心 + 链表】
题目链接:BZOJ - 1150 题目分析 可以看出,我们选的 k 条边一定是相邻两点之间的线段.我们可以将每条边看成一个点,那么我们就是要在 n-1 个点中选出互不相邻的 k 个,使它们的和最小. ...
- bzoj 1150: [CTSC2007]数据备份Backup
Description 你在一家 IT 公司为大型写字楼或办公楼(offices)的计算机数据做备份.然而数据备份的工作是枯燥乏味 的,因此你想设计一个系统让不同的办公楼彼此之间互相备份,而你则坐在家 ...
- BZOJ 1150 [CTSC2007]数据备份Backup(贪心+优先队列)
[题目链接] http://www.lydsy.com/JudgeOnline/problem.php?id=1150 [题目大意] 给出n个数,请你挑出k对(每个数不可重复选取),使得他们差的绝对值 ...
- BZOJ 1150 CTSC2007 数据备份Backup 堆+馋
标题效果:给定一个长度n−1n-1的序列,要求选出kk个不相邻的数使得和最小 费用流显然能跑.并且显然过不去- - 考虑用堆模拟费用流 一个错误的贪心是每次取最小.这样显然过不去例子 我们把[每次取最 ...
- bzoj 1150: [CTSC2007]数据备份Backup【链表+堆】
参考:http://blog.csdn.net/Regina8023/article/details/44158947 神奇的做法.题意相当于若干个数取不相邻的k个使最小.先把数组差分,len表示这段 ...
- 【BZOJ 1150】 1150: [CTSC2007]数据备份Backup (贪心+优先队列+双向链表)
1150: [CTSC2007]数据备份Backup Description 你在一家 IT 公司为大型写字楼或办公楼(offices)的计算机数据做备份.然而数据备份的工作是枯燥乏味 的,因此你想设 ...
- 1150: [CTSC2007]数据备份Backup
1150: [CTSC2007]数据备份Backup https://lydsy.com/JudgeOnline/problem.php?id=1150 分析: 堆+贪心. 每次选最小的并一定是最优的 ...
- bzoj1150 [CTSC2007]数据备份Backup 双向链表+堆
[CTSC2007]数据备份Backup Time Limit: 10 Sec Memory Limit: 162 MBSubmit: 2727 Solved: 1099[Submit][Stat ...
- 【BZOJ1150】[CTSC2007]数据备份Backup 双向链表+堆(模拟费用流)
[BZOJ1150][CTSC2007]数据备份Backup Description 你在一家 IT 公司为大型写字楼或办公楼(offices)的计算机数据做备份.然而数据备份的工作是枯燥乏味的,因此 ...
随机推荐
- [读书笔记] R语言实战 (十四) 主成分和因子分析
主成分分析和探索性因子分析是用来探索和简化多变量复杂关系的常用方法,能解决信息过度复杂的多变量数据问题. 主成分分析PCA:一种数据降维技巧,将大量相关变量转化为一组很少的不相关变量,这些无关变量称为 ...
- java对word文档的操作(提取标题和内容等)-直接操作或poi工具包或freemarker+xml或html转word
1,java自带工具包实现对word的排版和写入 import java.awt.Color; import java.io.FileNotFoundException; import java.io ...
- vue自定义组件并使用
以下是使用自己写的一个简单的文件上传框为例 1.自定义组件结构(一个js文件,一个vue文件),最好单独放一个文件 2.upload.vue 内容 其中,action是父组件传递给子组件的参数,使用p ...
- jvm 虚拟机的组成部分
1.类加载子系统 :负责从文件系统或者网络中加载 Class 信息,加载的信息存放在 一块称之为方法区的内存空间 2.方法区:存放类信息,常量信息,常量池信息,包括字符串字面量和数字常量等 3.Jav ...
- (转)Linux内核 TCP/IP、Socket参数调优
Doc1: /proc/sys/net目录 所有的TCP/IP参数都位于/proc/sys/net目录下(请注意,对/proc/sys/net目录下内容的修改都是临时的,任何修改在系统重启后都会丢失) ...
- 洛谷—— P1640 [SCOI2010]连续攻击游戏
https://www.luogu.org/problem/show?pid=1640 题目描述 lxhgww最近迷上了一款游戏,在游戏里,他拥有很多的装备,每种装备都有2个属性,这些属性的值用[1, ...
- 数据库联表统计查询 Group by & INNER JOIN
原数据表 视频信息表 tab_video_info 播放记录表 tab_play_record 需求 统计播放量(已经开始播放)最多的前20个视频: SELECT a.video_id, SUM( ...
- intellij idea 打开两个 terminal
intellij idea 打开两个 terminal alt+f12可以打开terminal,在terminal窗口左侧点击绿色的加号,就可以又打开一个terminal,用tab标签展示:
- cocos2d-x ios游戏开发初认识(九) 音效、粒子系统与存储
我们知道.一个游戏少不了声音.一些好听的声音会提起你对游戏的兴趣,当然做好听的声音不是我们要学的,我们的目的是把声音在适当的时候放出来.顺便在这节中会说下简单的粒子系统和文件存储. 一.声音的播放: ...
- JBoss AS 7之文件夹结构(The Return Of The King)
1.2 JBoss As 7体系结构 以下介绍一下JBoss的体系结构,详细的文件夹结构. 假设熟悉曾经JBoss版本号的人,一定会发现JBoss AS 7与之前的JBoss的文件夹结构有了非常大的不 ...