[IOI2000] 邮局 加强版 题解

考虑动态规划,设 \(f_{i,j}\) 为经过了 \(i\) 个村庄,正在建第 \(j\)​ 个邮局的最优距离。

以及 \(w_{i,j}\) 表示区间 \([i,j]\)​ 内建一个邮局时的距离总和。

\(a\) 数组表示每个村庄的坐标编号。

朴素版状态转移方程:

\[f_{i,j}=\min(f_{i,j},f_{k,j-1}+w_{k+1,i})
\\ \\
k\in [0,i)
\]

根据初一上册数学,可知在区间 \([x,y]\) 中距离所有点的距离之和最短的点为:

若 \(2\mid x+y\),则点位于 \(\lfloor\frac{x+y}{2}\rfloor\)。

反之位于 \(\lfloor\frac{x+y+1}{2}\rfloor\)。

注意到,上述状态转移方程,有三个未知数:\(i,j,k\)。可得时间复杂度为 \(O(PV^3)\),肯定过不了。

考虑四边形不等式优化

注意到,\(w\)​ 函数的状态转移方程为:

\[w_{l,r+1}=w_{l,r}+a_{r+1}-a_{\lfloor\frac{l+r+1}{2}\rfloor}
\]

需要简化,过程如下,虽复杂,但重要,可加以理解。

\[\begin{cases}w_{l,r+1}=w_{l+r}+a_{r+1}-a_{\lfloor\frac{l+r+1}{2}\rfloor} \ 1式
\\
w_{l+1,r+1}=w_{l+1,r}+a_{r+1}-a_{\lfloor\frac{l+r+2}{2}\rfloor}\ 2式
\end{cases}
\\
\]

2式 \(-\) 1式,得:

\[w_{l+1,r+1}-w_{l,r+1}=w_{l+1,r}+a_{r+1}-a_{\lfloor\frac{l+r+2}{2}\rfloor}
-w_{l,r}-a_{r+1}+a_{\lfloor\frac{l+r+1}{2}\rfloor}\\
w_{l+1,r+1}-w_{l,r+1}=w_{l+1,r}-w_{l,r}+a_{\lfloor\frac{l+r+1}{2}\rfloor}
-a_{\lfloor\frac{l+r+2}{2}\rfloor}\\
w_{l+1,r+1}-w_{l,r+1}-w_{l+1,r}+w_{l,r}=a_{\lfloor\frac{l+r+1}{2}\rfloor}
-a_{\lfloor\frac{l+r+2}{2}\rfloor}
\]

\(\because\) 坐标单调上升

\[\therefore\ a_{\lfloor\frac{l+r+1}{2}\rfloor}\ \le \ a_{\lfloor\frac{l+r+2}{2}\rfloor}\\
\therefore\
a_{\lfloor\frac{l+r+1}{2}\rfloor}-a_{\lfloor\frac{l+r+2}{2}\rfloor}\le 0\\
w_{l+1,r+1}-w_{l,r+1}-w_{l+1,r}+w_{l,r}\le 0\\
w_{l,r}+w_{l+1,r+1}\le w_{l,r+1}+w_{l,r+1}\\
w_{l,r+1}+w_{l+1,r}\ge w_{l,r}+w_{l+1,r+1}
\]

通过四边形不等式可知,若 \(a,b,c,d\) 满足 \(a\le b \le c \le d\),且 \(w_{a,c}+w_{b,d}\le w_{a,d}+w_{b,d}\),则称 \(w\) 为四边形不等式,可以优化时间复杂度。

\(\because l\le l+1 \le r \le r+1\),则可以将 \(a,b,c,d\)​ 分别带入进去,即:

当 \(a=l,b=l+1,c=r,d=r+1\) 时:

\[w_{l,r+1}+w_{l+1,r}\ge w_{l,r}+w_{l+1,r+1}\\
w_{a,c}+w_{b,d}\ge w_{a,d}+w_{b,d}
\]

再附上1式 \(-\) 2式的:

\[w_{l,r+1}-w_{l+1,r+1}=w_{l,r}-a_{r+1}-a_{\lfloor\frac{l+r+1}{2}\rfloor}
-w_{l+1,r}+a_{r+1}+a_{\lfloor\frac{l+r+2}{2}\rfloor}
\\ \\
w_{l,r+1}-w_{l+1,r+1}=w_{l,r}-a_{\lfloor\frac{l+r+1}{2}\rfloor}-w_{l+1,r}+a_{\lfloor\frac{l+r+2}{2}\rfloor}
\\ \\
w_{l,r+1}-w_{l+1,r+1}-w_{l,r}+w_{l+1,r}=a_{\lfloor\frac{l+r+2}{2}\rfloor}
-a_{\lfloor\frac{l+r+1}{2}\rfloor}
\]

\(\because\) 坐标单调上升

\[\therefore a_{\lfloor\frac{l+r+2}{2}\rfloor}\ge a_{\lfloor\frac{l+r+1}{2}\rfloor}\\
a_{\lfloor\frac{l+r+2}{2}\rfloor}-a_{\lfloor\frac{l+r+1}{2}\rfloor}
\ge 0\\
w_{l,r+1}+w_{l+1,r}-w_{l+1,r+1}-w_{l,r}\ge 0
\\
w_{l,r+1}+w_{l+1,r} \ge w_{l+1,r+1}+w_{l,r}
\]

代码:

#include<bits/stdc++.h>
using namespace std;
const int MAXV=3003,MAXP=305,inf=1e9+5;
int v,p;
int f[MAXV][MAXP];//经过了i个村庄,正在建j个邮局
int a[MAXV],w[MAXV][MAXV],dp[MAXV][MAXP];
int minn,minid;
signed main(){
scanf("%d%d",&v,&p);
for(int i=1;i<=v;i++)
scanf("%d",&a[i]);
sort(a+1,a+v+1);
memset(f,0x3f,sizeof(f));
f[0][0]=0;
for(int i=1;i<=v;i++)
for(int j=i+1;j<=v;j++)
w[i][j]=w[i][j-1]+a[j]-a[i+j>>1];
for(int j=1;j<=p;j++)
{
dp[v+1][j]=v;
for(int i=v;i>=1;i--)
{
minn=inf;
for(int k=dp[i][j-1];k<=dp[i+1][j];k++)
{
if(f[k][j-1]+w[k+1][i]<minn)
{
minn=f[k][j-1]+w[k+1][i];
minid=k;
}
}
f[i][j]=minn;
dp[i][j]=minid;
}
}
printf("%d\n",f[v][p]);
return 0;
}

IOI2000 邮局 加强版 题解的更多相关文章

  1. BZOJXXXX: [IOI2000]邮局——四边形不等式优化初探

    貌似$BZOJ$上并没有这个题... 是嫌这个题水了么... 还是要氪金权限号??? 这里附上洛谷的题面:洛谷P4767 [IOI2000]邮局 题目描述 高速公路旁边有一些村庄.高速公路表示为整数轴 ...

  2. 1473. [Ioi2000]Post加强版 n log^2 n做法

    1473. [Ioi2000]Post加强版 n log^2 n做法 题面 有n个城市从负方向向正方向按照1至n标号,\(d[i]\)表示城市i离原点的距离并且\(d[1] = 0\),对于\(i \ ...

  3. COGS 1507. [IOI2000]邮局

    1507. [IOI2000]邮局 ★☆   输入文件:postoffice.in   输出文件:postoffice.out   简单对比时间限制:1 s   内存限制:256 MB [题目描述] ...

  4. 题解——洛谷P4767 [IOI2000]邮局(区间DP)

    这题是一道区间DP 思维难度主要集中在如何预处理距离上 由生活经验得,邮局放在中间显然最优 所以我们可以递推求出\( w[i][j] \)表示i,j之间放一个邮局得距离 然后设出状态转移方程 设\( ...

  5. 邮局加强版:四边形不等式优化DP

    题目描述 一些村庄建在一条笔直的高速公路边上,我们用一条坐标轴来描述这条公路,每个村庄的坐标都是整数,没有两个村庄的坐标相同.两个村庄的距离定义为坐标之差的绝对值.我们需要在某些村庄建立邮局.使每个村 ...

  6. P4767 [IOI2000]邮局 - 平行四边形不等式优化DP

    There is a straight highway with villages alongside the highway. The highway is represented as an in ...

  7. [IOI2000] 邮局

    ## 非常神仙的 wqs 二分优化dp,又学了一招. 首先我们需要先想到一个人类智慧版的前缀和优化. # part 1:violence 然鹅在前缀和优化之前我们先考虑暴力做法:我们可以枚举 i . ...

  8. [LUOGU] P4767 [IOI2000]邮局

    https://www.luogu.org/problemnew/show/P4767 四边形不等式好题! 可以设f[i][j]表示前i个村庄,建了j个邮局的最小代价. 转移:f[i][j]=min{ ...

  9. luogu_P4767 [IOI2000]邮局

    传送门 Description 高速公路旁边有一些村庄.高速公路表示为整数轴,每个村庄的位置用单个整数坐标标识.没有两个在同样地方的村庄.两个位置之间的距离是其整数坐标差的绝对值. 邮局将建在一些,但 ...

  10. GERALD07加强版题解

    题目描述: N个点M条边的无向图,询问保留图中编号在[l,r]的边的时候图中的联通块个数. 输入格式: 第一行四个整数N.M.K.type,代表点数.边数.询问数以及询问是否加密. 接下来M行,代表图 ...

随机推荐

  1. 用 Git 操作的数据库?这个项目火了!

    # 用 Git 操作的数据库?这个项目火了!> 超级特别又实用的数据库,快来补课!Git 是一个开源的分布式版本控制系统,可以敏捷高效地管理代码,让项目代码支持同时存在多个不同的版本和分支,是程 ...

  2. oeasy教您玩转vim - 17 - # 向上向下

    向上向下 回忆上节课内容 和 f 相关的是跳到 向 前 跳到是 f 向 后 跳到是 F 和 t 相关的是贴靠 向 前 贴靠是 t 向 后 贴靠是 T 和 小写 相关的是 向前 向前 跳跃是 f 向前 ...

  3. JavaScript小技巧~将伪数组转成数组的方法

    伪数组:具有数组结构但是五数组相关方法的类数组结构: 方式1:Array.from() 方式2:Array.prototype.slice.call(); 用方式1吧,好记简单

  4. 配置docker镜像时碰到的问题

    在配置docker镜像时,首先我是这样操作的 , echo "registry-mirrors": ["https://ry1ei7ga.mirror.aliyuncs. ...

  5. for循环以及常用的遍历(迭代)用法

    for循环以及常用的遍历(迭代)用法   概念:(概念才是高楼的地基!) for循环是一个计次循环,一般运用在循环次数已知的情况下.通常适用于枚举或遍历序列,以及迭代序列中的元素. 注意*:迭代变量用 ...

  6. 优化 GitHub 体验的浏览器插件「GitHub 热点速览」

    上周,GitHub 有个"安全问题"--CFOR(Cross Fork Object Reference)冲上了热搜,该问题的表现是: 远程仓库的提交内容任何人可以访问,即使已被删 ...

  7. 华为最高学术成果发表 —— 《Nature》正刊发表论文《Accurate medium-range global weather forecasting with 3D neural networks》

    论文<Accurate medium-range global weather forecasting with 3D neural networks>的<Nature>地址: ...

  8. 为wsl ubuntu设置固定IP

    参考: https://www.cnblogs.com/lidabo/p/16855858.html https://zhuanlan.zhihu.com/p/515068209 ========== ...

  9. Linux共享内存通信的C语言Demo代码

    重点注明: 本文代码来源于: https://blog.csdn.net/github_38294679/article/details/122360026 ===================== ...

  10. QT中Table Widget树控件的使用

    关于Item Widgets中Table Widget的使用方法!了解在QT程序中插入表格得操作! Table Widget树控件的使用 1.创建数据及其初始化Table控件 // 创建一英雄列表,一 ...