Codeforces Round #600 (Div. 2) E. Antenna Coverage(dp)

题目链接

题意:

m个Antenna,每个Antenna的位置是\(x_i\),分数是\(s_i\),覆盖范围是\([x_i - s_i; x_i + s_i]\),每个硬币可以使一个Antenna的\(s_i\)+1,求覆盖整个\([1;m]\)的最少硬币

思路:

\(f[pos][0]\)表示\([1,pos]\)没有被覆盖还要花费的最少硬币,\(f[pos][1]\)表示\([1,pos]\)被覆盖的最小花费硬币,对于每个\(pos\)枚举Antenna,有以下这几种情况

  • \(pos\)在\(x_i\)的右边,且Antenna\(i\)扩展到\(pos\)时的左边已经有Antenna覆盖,则Antenna\(i\)扩展到\(pos\)时\(f[pos][1] = min(f[pos][1],f[max(2*x[j]-pos-1,0)][1]+max(pos-x[j]-s[j],0));\)
  • \(pos\)在\(x_i\)的右边,且Antenna\(i\)扩展到\(pos\)时的左边无Antenna覆盖,则Antenna\(i\)扩展到\(pos\)时\(f[pos][1] = min(f[pos][1],f[max(2*x[j]-pos-1,0)][0]+1+max(pos-x[j]-s[j],0));\)
  • \(pos\)在\(x_i\)的左边,则只需扩展\(x_i\)的左侧\(f[pos][1] = min(f[pos][1],min(f[max(x[j]-s[j]-1,0)][1],f[max(x[j]-s[j],0)][0]));\)

\(f[i][1]\)和\(f[i][0]\)的区别是若左边已经有Antenna覆盖了,就可以少去覆盖\([i-1,i]\)的花费

代码:

#include <bits/stdc++.h>
using namespace std;
const int N = 200100;
int f[N][2],s[N],x[N];
int main()
{
int n,m;
cin >> n >> m;
for (int i = 1; i <= m; i++) f[i][0]=i-1,f[i][1]=1<<30;
f[0][1] = 0;
for (int i = 1; i <= n; i++)
{
cin >> x[i] >> s[i];
}
for (int i = 1; i<= m; i++)
for (int j = 1; j <= n;j++)
if ( i >= x[j])
{
f[i][1] = min(f[i][1],f[max(2*x[j]-i-1,0)][1]+max(i-x[j]-s[j],0));
f[i][1] = min(f[i][1],f[max(2*x[j]-i-1,0)][0]+1+max(i-x[j]-s[j],0));
}
else
{
f[i][1] = min(f[i][1],f[max(x[j]-s[j]-1,0)][1]);
f[i][1] = min(f[i][1],f[max(x[j]-s[j],0)][0]);
}
cout << f[m][1] << endl;
}

最新文章

  1. boldSystemFontOfSize 和 systemFontOfSize 的区别
  2. Qt自定义事件的实现(转)
  3. workplace background
  4. MapReduce实例浅析
  5. Java Socket编程示例
  6. Svn服务器的安装和配置
  7. MBProgressHUD框架的使用:https://github.com/jdg/MBProgressHUD
  8. POSIX、XNU
  9. 南京Uber优步司机奖励政策(1月18日~1月24日)
  10. 【转】java 文件 读取目录下的所有文件(包括子目录)
  11. Windows下将硬盘由MBR转为GPT
  12. 原生js实现轮播
  13. CS0016: 未能写入输出文件*****目录名称无效
  14. 读书笔记 effective c++ Item 42 理解typename的两种意义
  15. cocoapods的安装和使用以及版本升级遇到的问题
  16. htmlparser 学习
  17. BZOJ3252: 攻略 可并堆
  18. 分析技术和方法论营销理论知识框架,营销方面4P、用户使用行为、STP,管理方面5W2H、逻辑树、金字塔、生命周期
  19. BAT-SVN自动更新代码目录
  20. nginx rewrite规则实例讲解

热门文章

  1. Django 单表查询
  2. MongoDB 上手开发实践(入门上手开发这一篇就够了)
  3. Linux环境下详细讲解部署MySQL5.7版本
  4. C++ | C++ 基础知识 | 类型与声明
  5. Winform在控件内实现简单画笔功能
  6. Spring Boot2 系列教程(三十一)Spring Boot 构建 RESTful 风格应用
  7. python 生成器 yield语句
  8. 三个css属性 设置文字竖直居中
  9. pycharm 安装vue
  10. Qt Installer Framework翻译(3-5)