这题说的是n个城市 建路 使他们联通然后 , 可以使用一条超级的路这条路不计入总长,此时路长度为B, 这条路链接的两个城市人口与和为A+B, 然后计算出最大的A/B

解题

先生成一颗最小生成树,然后 计算出这颗树上每两个节点之间要经过的最长的那条路,然后枚举每两个节点u 个v 求出答案

 #include <iostream>
#include <algorithm>
#include <vector>
#include <cstdio>
#include <string.h>
#include <cmath>
using namespace std;
const int maxn =+;
struct Edge{
int u,v;
double dist;
bool operator <(const Edge &rhs)const{
return dist<rhs.dist;
}
};
vector<Edge>E;
struct point{
int x,y;
}LOC[maxn];
int P[maxn],fa[maxn];
double maxcost[maxn][maxn];
struct ed{
int to; double dist;
};
vector<ed>G[ maxn ];
int fid(int u){
return fa[u]==u? u :( fa[u] = fid( fa[u] ) );
}
vector<int>use;
void dfs(int u, int per,double cost){
for(int i =; i < (int )use.size(); i++){
int v = use[i];
maxcost[u][v] = maxcost[v][u] = max( maxcost[per][v], cost);
}
use.push_back(u);
for(int i =; i < (int)G[u].size() ; i++ ){
ed e = G[u][i];
if(e.to!=per) dfs(e.to,u,e.dist);
}
}
double distends(double x1, double y1, double x2, double y2){
return sqrt((x1-x2)*(x1-x2)+(y1-y2)*(y1-y2));
}
int main()
{
int cas;
scanf("%d",&cas);
for(int cc =; cc <= cas; ++cc ){
int n;
scanf("%d",&n);
for(int i=; i<n; i++){
scanf("%d%d%d",&LOC[i].x,&LOC[i].y,&P[i]);
G[i].clear(); fa[i] = i;
}
E.clear();
for(int i=; i < n; i++)
for(int j = i+; j < n; j++ ){
double d = distends(LOC[i].x,LOC[i].y, LOC[j].x, LOC[j].y);
E.push_back( (Edge){ i,j,d } );
}
sort(E.begin() , E.end());
double sum_dist=;
int ge=n;
for(int i =; i<(int)E.size(); i++ ){
int u = E[i].u, v = E[i].v;
double dist = E[i].dist;
int fu = fid(u),fv =fid(v);
if(fu != fv){
G[u].push_back( (ed){v,dist} ); G[v].push_back( (ed){u,dist} );
fa[ fu ] = fv;
sum_dist+=dist;
ge--; if(ge==) break;
}
}
memset(maxcost,,sizeof(maxcost));
use.clear();
dfs(,-,0.0);
double ans =;
for(int i =; i<n; i++)
for(int j =i+ ; j<n; j++ ){
double c = 1.0*(P[i]+P[j])/(sum_dist-maxcost[i][j]);
if(ans<c){
ans=c;
}
}
printf("%.2f\n",ans);
}
return ;
}

uva1494 最小生成树--例题的更多相关文章

  1. 【数据结构】 最小生成树(三)——prim算法

    上一期介绍到了kruskal算法,这个算法诞生于1956年,重难点就是如何判断是否形成回路,此处要用到并查集,不会用当然会觉得难,今天介绍的prim算法在kruskal算法之后一年(即1957年)诞生 ...

  2. 【数据结构】 最小生成树(四)——利用kruskal算法搞定例题×3+变形+一道大水题

    在这一专辑(最小生成树)中的上一期讲到了prim算法,但是prim算法比较难懂,为了避免看不懂,就先用kruskal算法写题吧,下面将会将三道例题,加一道变形,以及一道大水题,水到不用高级数据结构,建 ...

  3. 紫书 例题 11-14 UVa 1279 (动点最小生成树)(详细解释)

    这道题写了好久-- 在三维空间里面有动的点, 然后求有几次最小生成树. 其实很容易发现, 在最小生成树切换的时候,在这个时候一定有两条边相等, 而且等一下更大的那条边在最小生成树中,等一下更小的边不在 ...

  4. 紫书 例题 11-3 UVa 1151 (有边集的最小生成树+二进制枚举子集)

    标题指的边集是说这道题的套餐, 是由几条边构成的. 思路是先做一遍最小生成树排除边, 因为如果第一次做没有加入的边, 到后来新加入了很多权值为0的边,这些边肯定排在最前面,然后这条边的前面的那些边肯定 ...

  5. 【最小生成树之Kruskal例题-建设电力系统】-C++

    前置知识点Kruskal最短路算法,如果没掌握的请先去掌握! 描述 小明所在的城市由于下暴雪的原因,电力系统严重受损.许多电力线路被破坏,因此许多村庄与主电网失去了联系.政府想尽快重建电力系统,所以, ...

  6. acm常见算法及例题

    转自:http://blog.csdn.net/hengjie2009/article/details/7540135 acm常见算法及例题  初期:一.基本算法:     (1)枚举. (poj17 ...

  7. 次小生成树学习+例题 poj 1679 The Unique MST

    次小生成树学习: 顾名思义,次小生成树,就是将图的所有生成树排序后,权值第二小的生成树. 次小生成树的朴素求法是很好想的,即首先求出最小生成树,之后枚举最小生成树中的所有边,将当前枚举的边" ...

  8. 最小生成树之Kruskal(克鲁斯卡尔)算法

    学习最小生成树算法之前我们先来了解下下面这些概念: 树(Tree):如果一个无向连通图中不存在回路,则这种图称为树. 生成树 (Spanning Tree):无向连通图G的一个子图如果是一颗包含G的所 ...

  9. 最小生成树--克鲁斯卡尔算法(Kruskal)

    按照惯例,接下来是本篇目录: $1 什么是最小生成树? $2 什么是克鲁斯卡尔算法? $3 克鲁斯卡尔算法的例题 摘要:本片讲的是最小生成树中的玄学算法--克鲁斯卡尔算法,然后就没有然后了. $1 什 ...

随机推荐

  1. PCB 铺铜 转载

    所谓覆铜,就是将PCB上闲置的空间作为基准面,然后用固体铜填充,这些铜区又称为灌铜.敷铜的意义在于,减小地线阻抗,提高抗干扰能力:降低压降,提高电源效率:还有,与地线相连,减小环路面积.如果PCB的地 ...

  2. Mac - MySQL初始密码忘记重置MySQL root密码

    在什么情况下,需要重置root密码呢?那就是我们忘记了.还有一种比较坑的,那就是笔者的这种情况.按照正常的情况下,MySQL安装完之后,会弹出一个对话框,显示着一个临时的root密码,但无论笔者如何重 ...

  3. django和flask的区别

    转载至https://blog.csdn.net/tulan_xiaoxin/article/details/79132214 (1)Flask Flask确实很“轻”,不愧是Micro Framew ...

  4. Docker镜像制作

    使用docker原始源为centos制作一个nginx镜像 pull一个centos镜像 docker pull centos 运行进入容器 docker run -it centos 容器内安装wg ...

  5. What is Gensim?

    Gensim是一款开源的第三方Python工具包,用于从原始的非结构化的文本中,无监督地学习到文本隐层的主题向量表达.它支持包括TF-IDF,LSA,LDA,和word2vec在内的多种主题模型算法, ...

  6. related Field has invalid lookup: icontains 解决方法

    models.py 文件 # coding:utf8 from django.db import models class Book(models.Model):         name = mod ...

  7. Numba:高性能Python编译器

    一.简介 Numba是一个开源JIT编译器,它将Python和NumPy代码的子集转换为快速机器代码. 二.主要特点 加速Python功能 Numba使用行业标准的LLVM编译器库在运行时将Pytho ...

  8. easyui DataGrid表体单元格跨列rowspan

    最近做项目用到了jquery easyui,其中一组DataGrid做的报表是给客户大领导看的,客户要求报表样式跟他们原有系统的一模一样(如下图1). DataGrid样式好调,只是城市名称单元格跨行 ...

  9. LeetCode 第 338 题 (Counting Bits)

    Given a non negative integer number num. For every numbers i in the range 0 ≤ i ≤ num calculate the ...

  10. java string.getBytes(“UTF-8”) javascript equivalent

    1. byte[] bytes = "test.message".getBytes("UTF-8"); //result: [116, 101, 115, 11 ...