[APIO / CTSC2007]数据备份 --- 贪心
[APIO / CTSC 2007]数据备份
题目描述
你在一家 IT 公司为大型写字楼或办公楼(offices)的计算机数据做备份。
然而数据备份的工作是枯燥乏味的,因此你想设计一个系统让不同的办公楼彼此之间互相备份,而你则坐在家中尽享计算机游戏的乐趣。
已知办公楼都位于同一条街上。你决定给这些办公楼配对(两个一组)。
每一对办公楼可以通过在这两个建筑物之间铺设网络电缆使得它们可以互相备份。
然而,网络电缆的费用很高。当地电信公司仅能为你提供 K 条网络电缆,这意味着你仅能为 K 对办公楼(或总计 2K 个办公楼)安排备份。
任一个办公楼都属于唯一的配对组(换句话说,这 2K 个办公楼一定是相异的)。
此外,电信公司需按网络电缆的长度(公里数)收费。
因而,你需要选择这 K对办公楼使得电缆的总长度尽可能短。
换句话说,你需要选择这 K 对办公楼,使得每一对办公楼之间的距离之和(总距离)尽可能小。
下面给出一个示例,假定你有 5 个客户,其办公楼都在一条街上,如下图所示。
这 5 个办公楼分别位于距离大街起点 1km, 3km, 4km, 6km 和 12km 处。电信公司仅为你提供 K=2 条电缆。
上例中最好的配对方案是将第 1 个和第 2 个办公楼相连,第 3 个和第 4 个办公楼相连。
这样可按要求使用 K=2 条电缆。第 1 条电缆的长度是 3km―1km = 2km,第 2 条电缆的长度是 6km―4km = 2 km。
这种配对方案需要总长 4km 的网络电缆,满足距离之和最小的要求。
输入格式:
输入文件的第一行包含整数 n 和 k,其中 n(1≤n≤100 000)表示办公楼的数目,k(1≤k≤n/2)表示可利用的网络电缆的数目。
接下来的 n 行每行仅包含一个整数(0≤s≤1000 000 000), 表示每个办公楼到大街起点处的距离。这些整数将按照从小到大的顺序依次出现。
输出格式:
输出文件应当由一个正整数组成,给出将 2K 个相异的办公楼连成 K 对所需的网络电缆的最小总长度。
两个贪心混成的题。
第一个贪心:所选的网络电缆一定是连接相邻的办公楼。
证明:(虽然感觉像就非常像)如果有两对点不满足,那么一定是下列情况中的一种:
A1 A2 A3 A4 A5
1.A1连A2,A3连A5,很明显,A3连A4更优
2.A1连A3,A4连A2,那么A1连A2,A3连A4也更优(也说明连的区间不重合)
这样,可以知道相当于是在\((n-1)\)线段中选取\(k\)条不共点的线段。
也就是说,不能选择相邻的线段。
第二个贪心:同种树
考虑选了线段\(i\),怎么样表示选了线段\(i+1\)和线段\(i-1\)后比线段\(i\)更优呢?
选择线段\(i\)后,将线段\(i+1\)和线段\(i-1\)标记为不可选。
往堆中新添一个点\(p\),权值为\(val[i+1]+val[i-1]-val[i]\),那么选了点\(p\)就表示选择了线段\(i+1\)以及线段\(i-1\)
容易扩展到多个点的情况。
此时,单独的记录\(i+1\)和\(i-1\)是不行的,而是需要用一个链表来记录左右的节点。
时间复杂度\(O(k* \log n)\)
代码在此
转载于:https://www.cnblogs.com/reverymoon/p/8929459.html
[APIO / CTSC2007]数据备份 --- 贪心相关推荐
- BZOJ1150[CTSC2007]数据备份Backup——模拟费用流+堆+链表
题目描述 你在一家 IT 公司为大型写字楼或办公楼(offices)的计算机数据做备份.然而数据备份的工作是枯燥乏味 的,因此你想设计一个系统让不同的办公楼彼此之间互相备份,而你则坐在家中尽享计算机游 ...
- P3620-[APIO/CTSC2007]数据备份【贪心,堆,链表】
正题 题目链接:https://www.luogu.com.cn/problem/P3620 题目大意 一条线上有nnn个位置,选出kkk对使得它们的距离差之和最小. 解题思路 因为一定是连接相邻的最 ...
- bzoj1150 [CTSC2007]数据备份Backup
大概就是写了道生日礼物那个不知道叫啥的贪心..... 大概就是说这道题和那个比较像... 所以留着看看吧,哪天想起了回来做这道题咯~ 转载于:https://www.cnblogs.com/LLppd ...
- bzoj1150: [CTSC2007]数据备份Backup--贪心+优先队列维护堆
题目大意:将k对点两两相连,求最小长度 易证得,最优方案中,相连的办公楼一定是取相邻的比取不相邻的要更优 然后就可以用贪心来做这道题了.. 之前向CZL大神学习了用堆来贪心的做法orz 大概思路就是将 ...
- [BZOJ1150][CTSC2007]数据备份Backup
首先肯定要选择相邻的公司配对才会距离最小 先把两两之间的距离加入小根堆中 每次取出堆顶,加入答案,删掉左右线段,再扔进去len[l]+len[r]-len[now] 这样如果这个新点被取到,说明取两边 ...
- [APIO/CTSC 2007]数据备份(贪心+堆)
你在一家 IT 公司为大型写字楼或办公楼(offices)的计算机数据做备份.然而数据备份的工作是枯燥乏味的,因此你想设计一个系统让不同的办公楼彼此之间互相备份,而你则坐在家中尽享计算机游戏的乐趣. ...
- 洛谷 P3620 - P3621 数据备份、风铃、动物园(APIO 2007)
洛谷 P3620 - P3622 数据备份.风铃.动物园(2007 APIO) P3620 数据备份 题目描述: 思路: 我们先来将这道题简化一下: 将每一对相邻的建筑之间的空地看作一个点,点的权值即 ...
- 专题突破二之优先队列、st表——,Running Median,Sequence,Buy Low Sell High,数据备份,超级钢琴,ZQC的手办
文章目录 Running Median Sequence Buy Low Sell High [APIO/CTSC 2007] 数据备份 [NOI2010] 超级钢琴 「LibreOJ β Round ...
- mysql备份psb文件怎么打开_Navicat for MySQL 数据备份教程
原标题:Navicat for MySQL 数据备份教程 一个安全和可靠的服务器与定期运行备份有密切的关系,因为错误有可能随时发生,由攻击.硬件故障.人为错误.电力中断等都会照成数据丢失.备份功能为防 ...
最新文章
- SQL SERVER中Datetime时间的范围与.net的DateTime对象的区别
- SAP SD基础知识之创建并处理外向交货单
- 韦东奕陈杲同获达摩院青橙奖,90后数学新星光彩夺目,却说「没有黄金一代」...
- HTML+CSS实战作业
- java jmf 视屏监控的核心代码_JMF(Java Media Framework)使用摄像头
- redhat9Linux解压gz,linux (redhat9)下subversion 的安装
- 深入探究ASP.NET Core Startup的初始化
- php hugepage,【原创】解决Redis启动报错:Transparent Huge Pages (THP) support enabled in your kernel...
- 如何给Linux操作系统(CentOS 7为例)云服务器配置环境等一系列东西
- 澄海口袋机器人_汕头市澄海区在2019年汕头市中小学智能机器人竞赛上取得优异成绩...
- c语言较大的整型相加,二个超长正整数的相加
- python selenium list index out of range
- 数据仓库与数据挖掘(一)
- PHP中“简单工厂模式”实例讲解(转)
- 20145127 《Java程序设计》第四次实验报告
- paip.System.out.println乱码解决
- 电脑功耗监测_VOCS在线监测系统
- visual studio写python_将 Visual Studio 变身为 Python IDE
- VB/VBA之死,何时休?
- Oracle语法限制,in内元素数量必须不大于1000
热门文章
- wxpython 隐藏_使用cxFreeze冻结wxPython应用程序时如何隐藏控制台窗口?
- android命令行 gles,Android利用OpenGLES绘制天空盒实例教程
- python日期格式转换成13位时间戳_python生成13位或16位时间戳以及反向解析时间戳的实例...
- Java中判断字符串是否为数字
- Java并发编程之ConcurrentLinkedQueue详解
- Windows 禁止mysql 自动更新
- com/fasterxml/jackson/core/exc/InputCoercionException
- nginx 负载均衡 最初级版本
- bitcoin转账api,python2.7
- perf-perf stat用户层代码分析