【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的更多相关文章

  1. 【POJ2728】Desert King(分数规划)

    [POJ2728]Desert King(分数规划) 题面 vjudge 翻译: 有\(n\)个点,每个点有一个坐标和高度 两点之间的费用是高度之差的绝对值 两点之间的距离就是欧几里得距离 求一棵生成 ...

  2. 【POJ2728】Desert King - 01分数规划

    Description David the Great has just become the king of a desert country. To win the respect of his ...

  3. 【POJ2728】Desert King 最优比率生成树

    题目大意:给定一个 N 个点的无向完全图,边有两个不同性质的边权,求该无向图的一棵最优比例生成树,使得性质为 A 的边权和比性质为 B 的边权和最小. 题解:要求的答案可以看成是 0-1 分数规划问题 ...

  4. 【POJ 2728 Desert King】

    Time Limit: 3000MSMemory Limit: 65536K Total Submissions: 27109Accepted: 7527 Description David the ...

  5. 【HDOJ】【1512】Monkey King

    数据结构/可并堆 啊……换换脑子就看了看数据结构……看了一下左偏树和斜堆,鉴于左偏树不像斜堆可能退化就写了个左偏树. 左偏树介绍:http://www.cnblogs.com/crazyac/arti ...

  6. POJ2728:Desert King——题解

    http://poj.org/problem?id=2728 题目大意:求一棵生成树使得路费用和/路长之和最小(路的费用是两端点的高度差) 最小比率生成树. 我们还是01分数规划的思想将边权变为路费用 ...

  7. poj2728 Desert King【最优比率生成树】【Prim】【0/1分数规划】

    含[最小生成树Prim]模板. Prim复杂度为$O(n^2),适用于稠密图,特别是完全图的最小生成树的求解.   Desert King Time Limit: 3000MS   Memory Li ...

  8. POJ2728 Desert King 【最优比率生成树】

    POJ2728 Desert King Description David the Great has just become the king of a desert country. To win ...

  9. 【BZOJ】1087: [SCOI2005]互不侵犯King

    [算法]状态压缩型DP [题解]http://www.cnblogs.com/xtx1999/p/4620227.html (orz) https://www.cnblogs.com/zbtrs/p/ ...

随机推荐

  1. 查看C语言的方法名

    1,打开 Visual Studio 2008 x64 Win64 命令提示 2,查看dumpbin  –exports  [C动态库的路径]

  2. Cheatsheet: 2014 01.15 ~ 01.30

    Web How to upload file in Node.js Create Echo Server in Node.js Near-Realtime Analytics with MongoDB ...

  3. 如何解决Angular 2 的templateUrl和styleUrl的路径问题?

    参考地址:https://github.com/kittencup/angular2-ama-cn/issues/18 前言: templateUrl表示的是组件在浏览器中运行时依赖的模板地址,所以在 ...

  4. bootstrp水平表单格式

    1:form里添加类 "form-horizontal" 2:把标签和表单控件(input 等)放在一个带有类名 "form-group"的div里 3:标签可 ...

  5. 遇到问题-----JS中设置window.location.href跳转无效(在a标签里或这form表单里)

    问题情况 JS中设置window.location.href跳转无效 代码如下: ? 1 2 3 4 5 6 7 8 <script type="text/javascript&quo ...

  6. hdu 1217 (Floyd变形)

    链接:http://acm.hdu.edu.cn/showproblem.php?pid=1217 Arbitrage Time Limit: 2000/1000 MS (Java/Others)   ...

  7. python_way,day8 面向对象【多态、成员--字段 方法 属性、成员修饰符、特殊成员、异常处理、设计模式之单例模式、模块:isinstance、issubclass】

    python_way day8 一.面向对象三大特性: 多态 二.面向对象中的成员 字段.方法属性 三.成员修饰符 四.特殊成员 __init__.__doc__.__call__.__setitem ...

  8. Xcode:Foundation框架找不到,或者是自动提示出现问题

    问题描述:Foundation框架找不到,或者是自动提示出现问题 之前的操作:手贱,不少心把编译器里面的源码改了 处理办法:清理缓存 缓存位置:点击桌面后,选择系统菜单栏:前往—电脑—硬盘—用户—ap ...

  9. HTML笔记(六)文档类型

    <!DOCTYPE>声明帮助浏览器正确显示网页.一般放在页面的最前面. DTD是Document Type Definition的缩写,是一套关于标记符的语法规则,是一种文档验证机制. H ...

  10. flex中实现自动换行

    有时候由于label .button等控件中需要用到text属性显示出文本,文本太长就涉及到换行问题,解决方法如下 在actionScript 需要用“  ”实现换行,在需要换行的地方加上它就OK. ...