【poj2728】Desert King
【poj2728】Desert King
题意
最优比率生成树。
http://blog.csdn.net/ophunter_lcm/article/details/10113817
分析
Dinkelbach算法,通过迭代的思想进行参数搜索。
每一次的参数搜索,求出来的最小生成树又会生成一个更优的参数,然后用新的参数继续搜...以此类推。
为什么生成的参数会更优?
这是因为我们要最小化\(\sum C\over \sum D\),我们设答案为\({\sum C\over \sum D}<L\),这等价于\(\sum(C-DL)<0\)
我们满足以上等式,就是说明存在\(C,D\)满足\(\sum(C-DL)<0\),所以逆推回来就有\(L>{\sum C\over \sum D}\),且\(\sum C\over \sum D\)是可取的,所以就进一步的逼近了。
可以证明逼近最优解的次数为\(O(\log NC)\),即是一个\(\log\)级别的次数。
所以可以大胆地去用。
它跑得一般比二分还快。
但是适用的范围没有二分广。
总之具体问题具体分析。
为什么我的姿势这么挫,跑得这么慢...
#include <cstdio>
#include <cstring>
#include <cctype>
#include <climits>
#include <cmath>
#include <algorithm>
using namespace std;
#define rep(i,a,b) for (int i=(a);i<=(b);i++)
const int N=1024;
const int INF=INT_MAX;
const double MAX=1e10;
const double EPS=1e-4;
int n;
double x[N],y[N],z[N];
double d[N][N];
double h[N][N];
double ans;
double mp[N][N];
int vis[N]; double dis[N]; int src[N];
double sumD,sumH;
inline int cmp(double a,double b)
{
if (fabs(a-b)<EPS) return 0;
return a<b?-1:1;
}
inline double GetDis(double xi,double yi,double xj,double yj)
{
double dx=xi-xj,dy=yi-yj;
return sqrt(pow(dx,2)+pow(dy,2));
}
double Prim(void)
{
double sum=0;
memset(mp,0,sizeof mp);
memset(vis,0,sizeof vis); memset(dis,0,sizeof dis); memset(src,0,sizeof src);
sumD=sumH=0;
rep(i,1,n) rep(j,1,n)
mp[i][j]=h[i][j]-ans*d[i][j];
vis[1]=1; dis[1]=0; rep(i,2,n) dis[i]=mp[1][i],src[i]=1;
rep(tms,1,n-1)
{
double t=MAX; int frm=0,to=0;
rep(i,1,n) if (!vis[i])
if (dis[i]<t) t=dis[i],frm=src[i],to=i;
vis[to]=1;
sumD+=d[frm][to],sumH+=h[frm][to];
sum+=t;
rep(i,1,n) if (!vis[i])
if (mp[to][i]<dis[i]) dis[i]=mp[to][i],src[i]=to;
}
return sum;
}
int main(void)
{
#ifndef ONLINE_JUDGE
freopen("poj2728.in","r",stdin);
freopen("poj2728.out","w",stdout);
#endif
rep(tms,1,INF)
{
scanf("%d",&n); if (!n) break;
memset(x,0,sizeof x); memset(y,0,sizeof y); memset(z,0,sizeof z);
rep(i,1,n) scanf("%lf%lf%lf",x+i,y+i,z+i);
memset(d,0,sizeof d); memset(h,0,sizeof h);
rep(i,1,n) rep(j,1,n)
{
d[i][j]=GetDis(x[i],y[i],x[j],y[j]);
h[i][j]=fabs(z[i]-z[j]);
}
ans=MAX;
while (1)
{
double t=Prim();
if (cmp(t,0)!=0)
ans=sumH/sumD;
else break;
}
printf("%0.3lf\n",ans);
}
return 0;
}
【poj2728】Desert King的更多相关文章
- 【POJ2728】Desert King(分数规划)
[POJ2728]Desert King(分数规划) 题面 vjudge 翻译: 有\(n\)个点,每个点有一个坐标和高度 两点之间的费用是高度之差的绝对值 两点之间的距离就是欧几里得距离 求一棵生成 ...
- 【POJ2728】Desert King - 01分数规划
Description David the Great has just become the king of a desert country. To win the respect of his ...
- 【POJ2728】Desert King 最优比率生成树
题目大意:给定一个 N 个点的无向完全图,边有两个不同性质的边权,求该无向图的一棵最优比例生成树,使得性质为 A 的边权和比性质为 B 的边权和最小. 题解:要求的答案可以看成是 0-1 分数规划问题 ...
- 【POJ 2728 Desert King】
Time Limit: 3000MSMemory Limit: 65536K Total Submissions: 27109Accepted: 7527 Description David the ...
- 【HDOJ】【1512】Monkey King
数据结构/可并堆 啊……换换脑子就看了看数据结构……看了一下左偏树和斜堆,鉴于左偏树不像斜堆可能退化就写了个左偏树. 左偏树介绍:http://www.cnblogs.com/crazyac/arti ...
- POJ2728:Desert King——题解
http://poj.org/problem?id=2728 题目大意:求一棵生成树使得路费用和/路长之和最小(路的费用是两端点的高度差) 最小比率生成树. 我们还是01分数规划的思想将边权变为路费用 ...
- poj2728 Desert King【最优比率生成树】【Prim】【0/1分数规划】
含[最小生成树Prim]模板. Prim复杂度为$O(n^2),适用于稠密图,特别是完全图的最小生成树的求解. Desert King Time Limit: 3000MS Memory Li ...
- POJ2728 Desert King 【最优比率生成树】
POJ2728 Desert King Description David the Great has just become the king of a desert country. To win ...
- 【BZOJ】1087: [SCOI2005]互不侵犯King
[算法]状态压缩型DP [题解]http://www.cnblogs.com/xtx1999/p/4620227.html (orz) https://www.cnblogs.com/zbtrs/p/ ...
随机推荐
- android 入门 003 (点击事件)
点击事件 有四种实现方式. 1.内部类实现方式 1.0 package cn.rfvip.clickevent; import android.app.Activity; import android ...
- web打印
实现方法 引用jquery和,jqprint到您的页面 <script language="javascript" src="jquery-1.4.4.min.js ...
- 区分一下dpkg,rpm和yum以及apt-get
一般来说著名的 Linux 系统基本上分两大类: RedHat 系列:Redhat.Centos.Fedora 等 Debian 系列:Debian.Ubuntu 等 Dpkg (Debian系):U ...
- .Net操作.exe文件
Process proc = new Process(); proc.StartInfo.FileName = @"D:\Program Files\Foxmail\Foxmail.exe& ...
- spring事务管理-摘抄
原著网址 http://gcq04552015.iteye.com/blog/1666570 Spring是以代理的方式实现对事务的管理.我们在Action中所使用的Service对象,其实是代理对象 ...
- PostgresSql开放局域网访问
1) 确认已经退掉所有的MASF终端和MSF GUI,然后打开PostgresSQL的启动文件在文件POSTGRESQL_START参数后面添加-h 0.0.0.0,让PostgreSQL启动时绑定到 ...
- STORM_0006_第二个storm_topology:WordCountTopology的代码与运行
我先试试这个Open Live Writer能不能用. 再在ScribeFire中修改一下已经发布的文章试试看. 这两个写博客的地方都没有原始的编辑器方便,可以插入代码,选择文章的分类.所以以后还有这 ...
- javascript权威指南笔记--javascript语言核心(五)--getter和setter属性
getter和setter属性: var p = { x:1.0, y:1.0, get r(){ return Math.sqrt(this.x*this.x + this.y * this.y); ...
- yii2-获取配置选项的值
Yii::$app->属性值 e.g:echo Yii::$app->id #输出basic config: $config = [ 'id' => 'basic', 'basePa ...
- Python学习(4)运算符
目录 Python 算术运算符 Python 比较运算符 Python 赋值运算符 Python 位运算符 Python 逻辑运算符 Python 成员运算符 Python 身份运算符 Python ...