E. Antenna Coverage (dp)
题意: 在一个一维坐标上,有 n 个东西, 每个东西, 用 xi, si 表示 这个东西在 xi 位置上,
它能覆盖到的区间为 [ xi - si, xi + si ];
然后, 你可以对任意的东西, 扩大它的 覆盖区间, 即对 si 加 1; 花费1;
问你 覆盖 [ 1, m ] 的最少花费。
n <= 80, m <= 100000;
解: 显然 DP;
我们用 dp[ i ] 表示 覆盖 i ~ m 的最少花费。
然后我们从 m ~ 1 枚举 x;
若这个x 被某个东西覆盖, 则 dp[ i ] = dp[ i + 1 ];
否则, 枚举 所有的 n 个东西, 判断 那些 xi - si 大于你当前枚举的那个 x 的东西。
那么你设 dis = xi - si - x; 即你到那个东西覆盖的区间的左端点的距离。
然后, 因为它左边扩了 dis, 那么它右边也可以扩 dis;
那么,答案就是 dis + dp[ xi + si + dis];
然后, 最后 dp[ 1 ] 就是答案了。
#include <bits/stdc++.h>
#define LL long long
#define INF 0x3f3f3f3f
using namespace std;
struct note {
int l, r;
}a[];
bool cmp(note a, note b) {
return a.l == b.l ? a.r < b.r : a.l < b.l;
}
const int N = 2e5 + ;
int dp[N];
int main() { int n, m; scanf("%d %d", &n, &m);
for(int i = ; i <= m; i++) dp[i] = INF;
int ma = ;
for(int i = ; i <= n; i++) {
int x, s; scanf("%d %d", &x, &s);
a[i].l = max(x - s, ); a[i].r = min(x + s, m);
ma = max(ma, a[i].r);
for(int j = a[i].l; j <= a[i].r; j++) {
dp[j] = ;
}
}
for(int i = m; i > ma; i--) dp[i] = m - i + ;
// n++; a[n].l = n; a[n].r = n;
sort(a + , a + + n, cmp);
dp[m + ] = ;
for(int i = m; i >= ; i--) {
if(dp[i] == ) dp[i] = dp[i + ];
else {
for(int j = ; j <= n; j++) {
if(a[j].l > i) {
int dis = a[j].l - i;
int R = min(a[j].r + dis, m);
dp[i] = min(dp[i], dis + dp[R + ]);
}
}
}
}
printf("%d\n", dp[]);
}
E. Antenna Coverage (dp)的更多相关文章
- CF1253E Antenna Coverage(DP)
本题难点在正确性证明. 令 \(f_i\) 表示 \([1,i]\) 被全部覆盖的最小花费.答案为 \(f_m\). 首先发现,添加一个区间 \([0,0]\) 不会影响答案.所以 \(f_i\) 的 ...
- LightOJ 1033 Generating Palindromes(dp)
LightOJ 1033 Generating Palindromes(dp) 题目链接:http://acm.hust.edu.cn/vjudge/contest/view.action?cid= ...
- lightOJ 1047 Neighbor House (DP)
lightOJ 1047 Neighbor House (DP) 题目链接:http://acm.hust.edu.cn/vjudge/contest/view.action?cid=87730# ...
- UVA11125 - Arrange Some Marbles(dp)
UVA11125 - Arrange Some Marbles(dp) option=com_onlinejudge&Itemid=8&category=24&page=sho ...
- 【POJ 3071】 Football(DP)
[POJ 3071] Football(DP) Time Limit: 1000MS Memory Limit: 65536K Total Submissions: 4350 Accepted ...
- 初探动态规划(DP)
学习qzz的命名,来写一篇关于动态规划(dp)的入门博客. 动态规划应该算是一个入门oier的坑,动态规划的抽象即神奇之处,让很多萌新 萌比. 写这篇博客的目标,就是想要用一些容易理解的方式,讲解入门 ...
- Python项目在Jenkins中的自动化测试实践(语法检查、单元测试,coverage(代码覆盖率)、自动打包)
原始链接:http://blog.csdn.net/a464057216/article/details/52934077 requirments OS: Ubuntu 14.04+ Gitlab 8 ...
- Tour(dp)
Tour(dp) 给定平面上n(n<=1000)个点的坐标(按照x递增的顺序),各点x坐标不同,且均为正整数.请设计一条路线,从最左边的点出发,走到最右边的点后再返回,要求除了最左点和最右点之外 ...
- 2017百度之星资格赛 1003:度度熊与邪恶大魔王(DP)
.navbar-nav > li.active > a { background-image: none; background-color: #058; } .navbar-invers ...
随机推荐
- Rdlc Mail Label
1.创建报表服务器项目RDLML. 2.新建共享数据源DataMailLabel,设置到数据库AdventureWorks的连接,并为报表指定相应的访问凭据. 3.选择Name.Color.Thumb ...
- 总结:WPF中MultiBinding多值绑定的方法
原文:总结:WPF中MultiBinding多值绑定的方法 一.Xaml中绑定代码: <TextBlock Grid.Row="5" Grid.Column="3 ...
- C++:构造函数
问题提出 默认初始化 答案 ▶问题提出 主要是在VC++ 2015里经常提示莫名其妙的编译错误. 分析一下,为什么Java里构造函数这个问题很简单: 1. C++里对象类型不止有按引用传递,还可能拷贝 ...
- Mybatis 复习
概述 mybatis 是一个用java编写的持久层框架, 它封装了jdbc操作的很多细节,使开发者只需要关注sql语句本身,而无需关注注册驱动,创建连接等繁杂过程,它使用了ORM思想实现了结果 集的封 ...
- webpack面试题
1.webpack的核心概念 Entry:入口,Webpack进行打包的起始点(文件) Output:出口,webpack编译打包生成的bundle(打包文件) Loader:模块加载(转换)器,将非 ...
- CRM BP函数
REPORT ZCRM_BP_TEST. """""""""""""& ...
- Kubernetes学习之路(28)之镜像仓库Harbor部署
Harbor的部署 官方文档 Harbor有两种安装的方式: 在线安装:直接从Docker Hub下载Harbor的镜像,并启动. 离线安装:在官网上下载离线安装包其地址为:https://githu ...
- springboot2.1.3 本地加载jar包+打包载入本地jar
项目已springboot为主,有时候我们需要引入的jar包并非maven公共库中存在(这里不谈私自搭建私库),那我们能否像普通的工程一样,导入自己手动添加的jar包文件呢? 答案是肯定的,来,一起往 ...
- Executors、ThreadPoolExecutor线程池讲解
官方+白话讲解Executors.ThreadPoolExecutor线程池使用 Executors:JDK给提供的线程工具类,静态方法构建线程池服务ExecutorService,也就是Thread ...
- Spring实战(第4版).pdf - 百度云资源
http://www.supan.vip/spring%E5%AE%9E%E6%88%98 Spring实战(第4版).pdf 关于本书 Spring框架是以简化Java EE应用程序的开发为目标而创 ...