题面

传送门

Sol

左右可以分开搞

然后就是要形成一个类似梳子的东西

设\(f[0/1][i][j]\)

\(0\)凹,\(1\)凸,\(i\)为行,可以滚一维,\(j\)为该行长度

\(f[0][i][j] = min(f[0][i - 1][j], f[1][i - 1][k]) + j - a[i]; k > j\)

\(f[1][i][j] = min(f[1][i - 1][j], f[0][i - 1][k]) + j - a[i]; k < j\)

然后是\(O(n^3)\)优化可以变成\(O(n^2)\)

可以有\(50\)

# include <bits/stdc++.h>
# define RG register
# define IL inline
# define Fill(a, b) memset(a, b, sizeof(a))
using namespace std;
const int INF(1e9);
const int _(1e6 + 5);
typedef long long ll; IL int Input(){
RG int x = 0, z = 1; RG char c = getchar();
for(; c < '0' || c > '9'; c = getchar()) z = c == '-' ? -1 : 1;
for(; c >= '0' && c <= '9'; c = getchar()) x = (x << 1) + (x << 3) + (c ^ 48);
return x * z;
} int n, l[_], r[_], ans, f[2][2][_], MX; IL int Solve(){
Fill(f, 63);
for(RG int i = r[1]; i <= MX; ++i) f[0][1][i] = i - r[1];
for(RG int i = 2; i <= n; ++i){
RG int p = i & 1, q = p ^ 1;
for(RG int j = 0; j < r[i]; ++j) f[0][p][j] = f[1][p][j] = INF;
for(RG int j = MX, mn = INF; j >= r[i]; --j){
f[0][p][j] = min(f[0][q][j], mn) + j - r[i];
mn = min(mn, f[1][q][j]);
}
RG int mn = INF;
for(RG int j = 0; j < r[i]; ++j) mn = min(mn, f[0][q][j]);
for(RG int j = r[i]; j <= MX; ++j){
f[1][p][j] = min(f[1][q][j], mn) + j - r[i];
mn = min(mn, f[0][q][j]);
}
}
RG int ret = INF;
for(RG int i = r[n]; i <= MX; ++i) ret = min(ret, f[0][n & 1][i]);
return ret;
} int main(RG int argc, RG char* argv[]){
n = Input();
for(RG int i = 1; i <= n; ++i)
l[i] = Input(), r[i] = Input(), MX = max(MX, r[i] + 1);
ans += Solve();
for(RG int i = 1; i <= n; ++i) r[i] = MX - l[i];
printf("%d\n", ans + Solve());
return 0;
}

正解有个结论,这一行的\(dp\)值只跟上下两行的长度有关

并且只能为所有的\([a[i], a[i]+2]\)的并

然后不会证明

看代码就会写了

# include <bits/stdc++.h>
# define RG register
# define IL inline
# define Fill(a, b) memset(a, b, sizeof(a))
using namespace std;
const int INF(1e9);
const int _(1e6 + 5);
typedef long long ll; IL int Input(){
RG int x = 0, z = 1; RG char c = getchar();
for(; c < '0' || c > '9'; c = getchar()) z = c == '-' ? -1 : 1;
for(; c >= '0' && c <= '9'; c = getchar()) x = (x << 1) + (x << 3) + (c ^ 48);
return x * z;
} int n, l[_], r[_], ans, f[2][2][_], MX, g[2][_], t[2]; IL int Solve(){
Fill(f, 63), t[1] = 0; RG int rr = min(3, n);
for(RG int i = 1; i <= rr; ++i)
for(RG int j = r[i]; j <= r[i] + 2; ++j)
if(j >= r[1]) g[1][++t[1]] = j;
for(RG int i = 1; i <= t[1]; ++i) f[0][1][i] = g[1][i] - r[1];
for(RG int i = 2; i <= n; ++i){
RG int q = i & 1, p = q ^ 1; t[q] = 0;
RG int ll = max(1, i - 2), rr = min(i + 2, n);
for(RG int j = ll; j <= rr; ++j)
for(RG int k = r[j]; k <= r[j] + 2; ++k)
if(k >= r[i]) g[q][++t[q]] = k;
for(RG int j = 1; j <= t[q]; ++j){
f[0][q][j] = f[1][q][j] = INF;
for(RG int k = 1; k <= t[p]; ++k){
if(g[p][k] > g[q][j]) f[0][q][j] = min(f[0][q][j], f[1][p][k]);
else if(g[p][k] < g[q][j]) f[1][q][j] = min(f[1][q][j], f[0][p][k]);
else f[0][q][j] = min(f[0][q][j], f[0][p][k]), f[1][q][j] = min(f[1][q][j], f[1][p][k]);
}
f[0][q][j] += g[q][j] - r[i], f[1][q][j] += g[q][j] - r[i];
}
}
RG int ret = INF, q = n & 1;
for(RG int i = 1; i <= t[q]; ++i) ret = min(ret, f[0][q][i]);
return ret;
} int main(RG int argc, RG char* argv[]){
freopen("worm.in", "r", stdin);
freopen("worm.out", "w", stdout);
n = Input();
for(RG int i = 1; i <= n; ++i)
l[i] = Input(), r[i] = Input(), MX = max(MX, r[i] + 1);
ans += Solve();
for(RG int i = 1; i <= n; ++i) r[i] = MX - l[i];
printf("%d\n", ans + Solve());
return 0;
}

Bzoj1496: [NOI2006]千年虫的更多相关文章

  1. bzoj AC倒序

    Search GO 说明:输入题号直接进入相应题目,如需搜索含数字的题目,请在关键词前加单引号 Problem ID Title Source AC Submit Y 1000 A+B Problem ...

  2. [NOI2006] 最大获利

    [NOI2006] 最大获利 ★★★☆   输入文件:profit.in   输出文件:profit.out   简单对比时间限制:2 s   内存限制:512 MB [问题描述] 新的技术正冲击着手 ...

  3. BZOJ1497: [NOI2006]最大获利[最小割 最大闭合子图]

    1497: [NOI2006]最大获利 Time Limit: 5 Sec  Memory Limit: 64 MBSubmit: 4375  Solved: 2142[Submit][Status] ...

  4. BZOJ 1497: [NOI2006]最大获利 最小割

    1497: [NOI2006]最大获利 题目连接: http://www.lydsy.com/JudgeOnline/problem.php?id=1497 Description 新的技术正冲击着手 ...

  5. BZOJ_1497_[NOI2006]_最大获利_(最大流+最大权闭合图)

    描述 http://www.lydsy.com/JudgeOnline/problem.php?id=1497 共n个站点,给出建立每个站点所需要的花费.现在有m个客户需要开通服务,每个客户需要有两个 ...

  6. 网络流(最大流):COGS 28 [NOI2006] 最大获利

    28. [NOI2006] 最大获利 ★★★☆   输入文件:profit.in   输出文件:profit.out   简单对比 时间限制:2 s   内存限制:512 MB [问题描述] 新的技术 ...

  7. BZOJ 1416: [NOI2006]神奇的口袋( 高精度 )

    把x1~xn当成是1~n, 答案是不会变的. 然后直接模拟就行了...... P.S 双倍经验... BZOJ1416 && BZOJ1498 -------------------- ...

  8. BZOJ 1497: [NOI2006]最大获利( 最大流 )

    下午到周六早上是期末考试...但是我还是坚守在机房....要挂的节奏啊.... 这道题就是网络流 , 建图后就最大流跑啊跑啊跑... --------------------------------- ...

  9. BZOJ 1497: [NOI2006]最大获利(最大权闭合子图)

    1497: [NOI2006]最大获利 Time Limit: 5 Sec  Memory Limit: 64 MB Description 新的技术正冲击着手机通讯市场,对于各大运营商来说,这既是机 ...

随机推荐

  1. 【BZOJ1296】[SCOI2009]粉刷匠 (DP+背包)

    [SCOI2009]粉刷匠 题目描述 \(windy\)有 \(N\) 条木板需要被粉刷. 每条木板被分为 \(M\) 个格子. 每个格子要被刷成红色或蓝色. \(windy\)每次粉刷,只能选择一条 ...

  2. css第一篇:元素选择器

    1:多个选择器 h1, h2 {}       ——h1或h2标签的所有元素 2:通配选择器 * {}     ——所有元素 3:元素选择器 div {}   ——所有div元素 4:类选择器 .te ...

  3. jdbc连接oracle的url的三种写法

    JDBC 链接oracle的三种URL写法 1.普通SID方式     jdbc:oracle:thin:username/password@x.x.x.1:1521:SID 2.普通ServerNa ...

  4. SPOJ 1811 Longest Common Substring(求两个串的最长公共子串 || 或者n个串)

    http://www.spoj.com/problems/LCS/ 题目:求两个串的最长公共子串 参考:https://www.cnblogs.com/autoint/p/10345276.html: ...

  5. 3. Javascript学习笔记——变量、内存、作用域

    3. 变量.内存.作用域 3.1 基本类型和引用类型的值 ECMAScript 变量可能包含两种不同数据类型的值:基本类型值[Undefined.Null.Boolean.Number 和 Strin ...

  6. centos 7 设置开机启动服务

    2018-12-25 Centos7下添加开机自启动脚本和服务的方法 以docker 服务为例 1.centos7自带命令设置 systemctl enable docker.service 2.设置 ...

  7. CentOS&.NET Core初试-2-安装.NET Core SDK和发布网站

    系列目录 CentOS的安装和网卡的配置 安装.NET Core SDK和发布网站 Nginx的安装和配置 安装守护服务(Supervisor) 安装.NET Core SDK 注册Microsoft ...

  8. 解决 jenkins 下使用 HTML Publisher 插件后查看 html 报告显示不正常

    查看官方文档后,原来是安全问题所导致的. Jenkins安全默认是将以下功能都关闭了1.javascript2.html上的内置插件3.内置css或从其它站的css4.从其它站的图处5.AJAX 我的 ...

  9. c/c++ int long float double 表示范围

    引自https://blog.csdn.net/xuexiacm/article/details/8122267

  10. 修改linux系统用户、PostgreSQL用户的密码

    1. 修改linux系统postgres用户的密码 PostgreSQL会创建一个默认的linux用户postgres,修改该用户密码的方法如下: 步骤一:删除用户postgres的密码 sudo   ...