【四边形不等式】POJ1160[IOI2000]-Post Office
【题目大意】
v个村庄p个邮局,邮局在村庄里,给出村庄的位置,求每个村庄到最近邮局距离之和的最小值。
【思路】
四边形不等式,虽然我并不会证明:(
dp[i][j]表示前i个村庄建j个邮局的最小值,w[i][j]表示在i到j之间建立一个邮局的最小值。w[i][j]显然取i~j的中位数,可以在O(1)时间内求出。
显然dp[i][j]=min{dp[k][j-1]+w[k+1][i]}。
傻傻写错i和j……
#include<iostream>
#include<cstdio>
#include<cstring>
#include<algorithm>
#include<cmath>
using namespace std;
const int MAXV=;
const int MAXP=;
const int INF=0x7fffffff;
int v,p;
int dis[MAXV],sum[MAXV],w[MAXV][MAXV];//w[i][j]表示在[i,j]间建立一个邮局的最小代价
int s[MAXV][MAXP],dp[MAXV][MAXP]; void init()
{
scanf("%d%d",&v,&p);
sum[]=;
for (int i=;i<=v;i++) scanf("%d",&dis[i]);
sort(dis+,dis+v+);
for (int i=;i<=v;i++) sum[i]=dis[i]+sum[i-];
for (int i=;i<=v;i++)
{
w[i][i]=;
for (int j=i+;j<=v;j++)
{
if ((i+j)%==) w[i][j]=sum[j]-sum[(i+j)/]-sum[(i+j)/-]+sum[i-];
else w[i][j]=sum[j]-sum[(i+j)/]-sum[(i+j)/-]+sum[i-]-dis[(i+j)/];
}
}
} void solve()
{
memset(dp,,sizeof(dp));
for (int i=;i<=v;i++) dp[i][]=w[][i];
for (int j=;j<=p;j++)
{
s[v+][j]=v-;
for (int i=v;i>=j;i--)
{
for (int k=s[i][j-];k<=s[i+][j];k++)
{
if (dp[i][j]>dp[k][j-]+w[k+][i])//一开始这里敲成了w[k+1][j]
{
dp[i][j]=dp[k][j-]+w[k+][i];
s[i][j]=k;
}
}
}
}
printf("%d",dp[v][p]);
} int main()
{
init();
solve();
return ;
}
【四边形不等式】POJ1160[IOI2000]-Post Office的更多相关文章
- [poj1160][IOI2000]Post Office【动态规划】
		
传送门 https://vjudge.net/problem/POJ-1160#author=SCU2018 题目描述 在一条水平的公路上建有n个小屋,两个小屋间的距离是它们的横坐标之差的绝对值.保证 ...
 - POJ 1160 四边形不等式优化DP Post Office
		
d(i, j)表示用i个邮局覆盖前j个村庄所需的最小花费 则有状态转移方程:d(i, j) = min{ d(i-1, k) + w(k+1, j) } 其中w(i, j)的值是可以预处理出来的. 下 ...
 - IOI2000 Post Office (POJ1160)
		
前言 昨天XY讲课!讲到这题!还是IOI的题!不过据说00年的时候DP还不流行. 题面 http://poj.org/problem?id=1160 分析 § 1 中位数 首先我们考虑,若有x1 & ...
 - POJ-1160 Post Office (DP+四边形不等式优化)
		
题目大意:有v个村庄成直线排列,要建设p个邮局,为了使每一个村庄到离它最近的邮局的距离之和最小,应该怎样分配邮局的建设,输出最小距离和. 题目分析:定义状态dp(i,j)表示建设 i 个邮局最远覆盖到 ...
 - [POJ1160] Post Office [四边形不等式dp]
		
题面: 传送门 思路: dp方程实际上很好想 设$dp\left[i\right]\left[j\right]$表示前$j$个镇子设立$i$个邮局的最小花费 然后状态转移: $dp\left[i\ri ...
 - 石子合并(四边形不等式优化dp)  POJ1160
		
该来的总是要来的———————— 经典问题,石子合并. 对于 f[i][j]= min{f[i][k]+f[k+1][j]+w[i][j]} From 黑书 凸四边形不等式:w[a][c]+w[b][ ...
 - BZOJXXXX: [IOI2000]邮局——四边形不等式优化初探
		
貌似$BZOJ$上并没有这个题... 是嫌这个题水了么... 还是要氪金权限号??? 这里附上洛谷的题面:洛谷P4767 [IOI2000]邮局 题目描述 高速公路旁边有一些村庄.高速公路表示为整数轴 ...
 - POJ.1160.Post Office(DP 四边形不等式)
		
题目链接 \(Description\) 一条直线上有n个村庄,位置各不相同.选择p个村庄建邮局,求每个村庄到最近邮局的距离之和的最小值. \(Solution\) 先考虑在\([l,r]\)建一个邮 ...
 - POJ 1160 Post Office (四边形不等式优化DP)
		
题意: 给出m个村庄及其距离,给出n个邮局,要求怎么建n个邮局使代价最小. 析:一般的状态方程很容易写出,dp[i][j] = min{dp[i-1][k] + w[k+1][j]},表示前 j 个村 ...
 
随机推荐
- 【洛谷 P4166】 [SCOI2007]最大土地面积(凸包,旋转卡壳)
			
题目链接 又调了我两个多小时巨亏 直接\(O(n^4)\)枚举4个点显然不行. 数据范围提示我们需要一个\(O(n^2)\)的算法. 于是\(O(n^2)\)枚举对角线,然后在这两个点两边各找一个点使 ...
 - bzoj 3522 tree-dp 暴力
			
首先我们知道,这个题可以N^2的做,我们先确定一个根,然后讨论下情况,合法的三个点只可能有三种情况,第一种是三个点有相同的lca,这种情况我们可以用tree-dp来解决,用dis[i][j]表示i为根 ...
 - spring-boot-资源处理
			
WebMvcConfigurerAdapter 使用 1.实现 HandlerInterceptorAdapter 2.添加拦截器 重写WebMvcConfigurerAdapter中的addInte ...
 - python批量替换文件名
			
替换关键字 #-*-coding:utf-8-*- import os import re filepath = u'E:\\CMMI4\\07_测试文档' files = os.walk(filep ...
 - C# Selenium with PhantomJSDriver get image width and height (获取图片的长和高)
			
//get image width and height var image=driver.FindElement(By.ClassName("it-Header_authorImage&q ...
 - 实现UE添加自定义按钮之添加菜单
			
1.ueditor.config.js配置文件中配置 2.在ueditor.all.js配置文件中配置点开的的弹框位置 3.在ueditor1_4_3-utf8-jsp\themes\default\ ...
 - ssh登录时较慢的解决方法
			
ssh在登录的时候,通常都会经过DNS的反向解析,过程为: IP --> (反向DNS) --> hostname --> (DNS) --> IP 然后匹配开头申请的和最后得 ...
 - hashCode()与equals()区别
			
这两个方法均是超类Object自带的成员方法.Object类是所有Java类的祖先.每个类都使用 Object 作为超类.所有对象(包括数组)都实现这个类的方法.在不明确给出超类的情况下,Java会自 ...
 - MVC – 15.路由机制
			
15.1.路由检测插件 - RouteDebug 15.2.路由约束 15.3.命名路由 15.4.验证码 15.5.ASP.NET MVC 与 三层架构 15.6.Area区域 15.6.1.尝试将 ...
 - web2.0 HW3 相关阅读材料
			
W3C官网的材料简直看花眼……除了挂出的文档,www-style@w3.org的一堆邮件也藏着很多宝,但是看下来又眼花了……(好在宝们基本都被W3C吸收了=.=) 主要来自W3C的官网w3.org的一 ...