题目 http://poj.org/problem?id=2728

关键词:0/1分数规划,参数搜索,二分法,dinkelbach

参考资料:http://hi.baidu.com/zzningxp/item/28aa46e0fd86bdc2bbf37d03

http://hi.baidu.com/zheng6822/item/b31fbe9d5ae17536336eeb8f

#include<stdio.h>
#include<string.h>
#include<iostream>
#include<algorithm>
#include<stdlib.h>
#include<math.h>
#define N 1010
#define INF 1e15
#define eps 1e-10
using namespace std;
double X[N],Y[N],Z[N];
double cost[N][N];
double lowcost[N];
int closest[N];int vis[N];
int n;double r;
double disc(int i,int j)
{
return fabs(Z[i]-Z[j]);
}
double disd(int i,int j)
{
return sqrt((X[i]-X[j])*(X[i]-X[j])+(Y[i]-Y[j])*(Y[i]-Y[j]));
}
double prim(double r)
{
double sumc=;double sumd=;
for(int i=;i<n;i++)
for(int j=;j<n;j++)
{
if(i==j)
cost[i][j]=INF;
else
cost[i][j]=disc(i,j)-r*disd(i,j);
}
for(int i=;i<n;i++)
{
lowcost[i]=cost[][i];
vis[i]=;
closest[i]=;
}
closest[]=;
vis[]=;
int k;
for(int i=;i<n;i++)
{
double tmp=INF;
for(int j=;j<n;j++)
if(!vis[j]&&tmp>lowcost[j])
{
k=j;
tmp=lowcost[j];
}
vis[k]=;
for(int j=;j<n;j++)
if(!vis[j]&&lowcost[j]>cost[k][j])
{
lowcost[j]=cost[k][j];
closest[j]=k;
}
}
for(int i=;i<n;i++)
{
sumc+=disc(i,closest[i]);
sumd+=disd(i,closest[i]);
}
return sumc/sumd;
}
int main()
{
while(scanf("%d",&n)!=EOF&&n)
{
for(int i=;i<n;i++)
cin>>X[i]>>Y[i]>>Z[i];
double r1=,r2=;
while()
{
r2=prim(r1);
if(fabs(r1-r2)<=eps)
break;
r1=r2;
}
printf("%.3f\n",r1);
}
return ;
}

PRIM+迭代法

主要算法部分的分析

double prim(double r)
{
/*根据题目要求和算法得到由新的权值组成的图,并且写出邻接矩阵*/
double sumc=0;double sumd=0;
for(int i=0;i<n;i++)
for(int j=0;j<n;j++)
{
if(i==j)
cost[i][j]=INF;
else
cost[i][j]=disc(i,j)-r*disd(i,j);
}
/*初始化*/
for(int i=0;i<n;i++)
{
lowcost[i]=cost[0][i];
vis[i]=0; /*判断该点是否已经在集合内*/
closest[i]=0; /*邻接点*/
}
/*将第一个点加入集合*/
closest[0]=0;
vis[0]=1;
int k;
for(int i=0;i<n;i++)
{
double tmp=INF;
/*通过一次循环找到与第一个点距离最短的点*/
for(int j=0;j<n;j++)
if(!vis[j]&&lowcosat[j]<tmp)
{
k=j;
tmp=lowcost[j];
}
/*将该点加入集合中*/
vis[k]=1;
/*这一步是更新其他的点到集合中的点的距离,closest是用来记录该点的前驱的点的数组,lowcost是用来记录其他点到MST的最短距离的数组,注意是到树上任意一点而不是其中某点*/
for(int j=0;j<n;j++)
if(!vis[j]&&lowcost[j]>cost[j][k])
{
lowcost[j]=cost[j][k];
closest[j]=k;
}
}
/*返回参数,用于迭代*/
for(int i=0;i<n;i++)
{
sumc+=disc(i,closest[i]);
sumd+=disd(i,closest[i]);
}
return sumc/sumd;
}

  

POJ2728 Desert King 最优比率生成树的更多相关文章

  1. POJ2728 Desert King —— 最优比率生成树 二分法

    题目链接:http://poj.org/problem?id=2728 Desert King Time Limit: 3000MS   Memory Limit: 65536K Total Subm ...

  2. POJ 2728 Desert King 最优比率生成树

    Desert King Time Limit: 3000MS   Memory Limit: 65536K Total Submissions: 20978   Accepted: 5898 [Des ...

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

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

  4. Desert King(最优比率生成树)

    Desert King Time Limit: 3000MS   Memory Limit: 65536K Total Submissions: 22717   Accepted: 6374 Desc ...

  5. POJ.2728.Desert King(最优比率生成树 Prim 01分数规划 二分/Dinkelbach迭代)

    题目链接 \(Description\) 将n个村庄连成一棵树,村之间的距离为两村的欧几里得距离,村之间的花费为海拔z的差,求花费和与长度和的最小比值 \(Solution\) 二分,假设mid为可行 ...

  6. POJ 2728 Desert King(最优比率生成树, 01分数规划)

    题意: 给定n个村子的坐标(x,y)和高度z, 求出修n-1条路连通所有村子, 并且让 修路花费/修路长度 最少的值 两个村子修一条路, 修路花费 = abs(高度差), 修路长度 = 欧氏距离 分析 ...

  7. POJ 2728 Desert King (最优比率树)

    题意:有n个村庄,村庄在不同坐标和海拔,现在要对所有村庄供水,只要两个村庄之间有一条路即可,建造水管距离为坐标之间的欧几里德距离,费用为海拔之差,现在要求方案使得费用与距离的比值最小,很显然,这个题目 ...

  8. poj-2728Desert King(最优比率生成树)

    David the Great has just become the king of a desert country. To win the respect of his people, he d ...

  9. POJ 2728 Desert King (最优比例生成树)

    POJ2728 无向图中对每条边i 有两个权值wi 和vi 求一个生成树使得 (w1+w2+...wn-1)/(v1+v2+...+vn-1)最小. 采用二分答案mid的思想. 将边的权值改为 wi- ...

随机推荐

  1. Bootstrap按钮组学习

    简介 通过按钮组容器把一组按钮放在同一行里.通过与按钮插件联合使用,可以设置为单选框或多选框的样式和行为. 按钮组中的工具提示和弹出框需要特别的设置 当为 .btn-group 中的元素应用工具提示或 ...

  2. 通过CFX发布WebService(一)

    发布WebService的方法很多.如XFire,CFX等.现在首先介绍下怎样通过CFX来发部一个WebService. (1) 首先,是从Apache官方网站获取CFX的Java包.其地址是:htt ...

  3. Codeforces Round #522 (Div. 2, based on Technocup 2019 Elimination Round 3) Solution

    A. Kitchen Utensils Water. #include <bits/stdc++.h> using namespace std; #define N 110 int n, ...

  4. 字节跳动冬令营网络赛 Solution

    A:Aloha Unsolved. B:Origami Unsolved. 题意: 初始的时候有一张纸,可以从左边往右边折叠,或者从右边往左边折叠 每次折叠的长度不能超过现有宽度,最后折叠到长度为1 ...

  5. springcloud20---Config加入eureka

    Config server也可以加用户名和密码.Config client通过用户名和密码访问. Config server也可以做成高可用集群. Config与eureka配置使用.把Config ...

  6. 【运维技术】shell脚本实现线程挂掉,自动重启功能

    由于分布式系统的流行,服务器上面部署的项目都是多实例的.而我又希望有一个功能,当服务器出现异常情况能够自动重启实例. 所以我想到了使用shell脚本监控实例进程id,如果不存在的话,就重启对应的实例. ...

  7. 科幻小说《霜与火》 by 雷·布雷德伯里

    漫漫长夜中,西姆出世了,躺在山洞冰凉的石头上,嗷嗷大哭,浑身血液奔流,脉搏每分钟一千跳.他不停地长大.妈妈用发烫的双手喂西姆吃东西.人生的梦魔开场了.一来到世间,他的眼睛就闪烁着警觉的光芒:而后又令人 ...

  8. linux下运行jar

    方式一: java -jar XXX.jar 特点:当前ssh窗口被锁定,可按CTRL + C打断程序运行,或直接关闭窗口,程序退出 那如何让窗口不锁定? 方式二: java -jar XXX.jar ...

  9. UVA-10801 Lift Hopping (最短路)

    题目大意及分析:一道简单的最短路...好几天没写程序了,憋得难受!!! 代码如下: # include<iostream> # include<cstdio> # includ ...

  10. Mybatis整合Spring -- typeAliasesPackage

    Mybatis整合Spring 根据官方的说法,在ibatis3,也就是Mybatis3问世之前,Spring3的开发工作就已经完成了,所以Spring3中还是没有对Mybatis3的支持. 因此由M ...