[UVA1494] Qin Shi Huang's National Road System
题目
题解
从今天起我要改邪归正,好好刷题准备联赛!
这是一道经典的最小生成树题目。
枚举每一条边作为道士要修的路,求出包含这条边的最小生成树。
先求出原图的最小生成树。
如果要删的边在最小生成树上,那仍是原来那个最小生成树。
如果不在,便要把这条边加进去。类似次小生成树,删除原最小生成树中这两点间唯一路径上边权最大的边,并把这条边加进去。
我们要预处理最小生成树上两点间路径上边权最大的边,设它的边权为 \(f[u][v]\)
在求最小生成树的同时 借助父节点更新某一节点到已有生成树中其它节点的 \(f\) 值,复杂度 \(O(n^2)\)
代码
#include<cstdio>
#include<iostream>
#include<algorithm>
#include<cmath>
#include<queue>
using namespace std;
const int N = 1005;
typedef double db;
typedef pair<double,int> P;
int w[N],vis[N];
db mp[N][N],a[N],b[N];
int n;
priority_queue< P, vector<P>, greater<P> > que;
db d[N],f[N][N],S;
int fa[N];
void prim(){
d[1]=0; vis[1]=1;
for(int i=2;i<=n;i++)
d[i]=mp[1][i],fa[i]=1,que.push(P(d[i],i));
while(!que.empty()){
int u=que.top().second;
que.pop();
if(vis[u]) continue;
for(int i=1;i<=n;i++)
if(vis[i]) {
if(i==fa[u]) f[i][u]=f[u][i]=mp[u][i];
else f[i][u]=f[u][i]=max(mp[u][fa[u]],f[fa[u]][i]);
}
vis[u]=1; d[u]=0;
S+=mp[u][fa[u]];
for(int v=1;v<=n;v++){
if(v==u) continue;
if(d[v]>mp[u][v])
fa[v]=u,d[v]=mp[u][v],que.push(P(d[v],v));
}
}
for(int i=1;i<=n;i++) vis[i]=0;
}
int main()
{
int T;
scanf("%d",&T);
while(T--){
scanf("%d",&n);
for(int i=1;i<=n;i++)
scanf("%lf%lf%d",&a[i],&b[i],&w[i]);
for(int i=1;i<n;i++)
for(int j=i+1;j<=n;j++)
mp[i][j]=mp[j][i]=sqrt((b[i]-b[j])*(b[i]-b[j])+(a[i]-a[j])*(a[i]-a[j]));
S=0;
prim();
db ans=0.0;
for(int i=1;i<n;i++)
for(int j=i+1;j<=n;j++)
ans=max(ans,(w[i]*1.0+w[j]*1.0)/(S-f[i][j]));
printf("%.2lf\n",ans);
}
return 0;
}
[UVA1494] Qin Shi Huang's National Road System的更多相关文章
- hdu 4081 Qin Shi Huang's National Road System (次小生成树)
Qin Shi Huang's National Road System Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 32768/3 ...
- UValive 5713 Qin Shi Huang's National Road System
Qin Shi Huang's National Road System Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 32768/3 ...
- hdu 4081 Qin Shi Huang's National Road System (次小生成树的变形)
题目:Qin Shi Huang's National Road System Qin Shi Huang's National Road System Time Limit: 2000/1000 M ...
- HDU 4081 Qin Shi Huang's National Road System 次小生成树变种
Qin Shi Huang's National Road System Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 32768/3 ...
- Qin Shi Huang's National Road System HDU - 4081(树形dp+最小生成树)
Qin Shi Huang's National Road System HDU - 4081 感觉这道题和hdu4756很像... 求最小生成树里面删去一边E1 再加一边E2 求该边两顶点权值和除以 ...
- [hdu P4081] Qin Shi Huang’s National Road System
[hdu P4081] Qin Shi Huang’s National Road System Time Limit: 2000/1000 MS (Java/Others) Memory Li ...
- HDU4081 Qin Shi Huang's National Road System 2017-05-10 23:16 41人阅读 评论(0) 收藏
Qin Shi Huang's National Road System ...
- HDU4081:Qin Shi Huang's National Road System (任意两点间的最小瓶颈路)
Qin Shi Huang's National Road System Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 32768/3 ...
- HDU 4081—— Qin Shi Huang's National Road System——————【次小生成树、prim】
Qin Shi Huang's National Road System Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 32768/3 ...
随机推荐
- 关于better-scroll的使用注意事项
better-scroll的原理 1.什么是 better-scroll? better-scroll 是一个移动端滚动的解决方案,它不仅可以做普通的滚动列表,还可以做轮播图.picker 等等. 2 ...
- jquery自己写的带左右箭头自动播放幻灯插件,简化
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/ ...
- Linux 内核Ksets 对象
很多情况, 一个 kset 看来象一个 kobj_type 结构的扩展; 一个 kset 是一个嵌入到相 同类型结构的 kobject 的集合. 但是, 虽然 struct kobj_type 关注的 ...
- vue-learning:10-template-ref
使用ref直接访问DOM元素 传统DOM操作或jQuery操作DOM,都必须是选择器先选择对应的DOM元素.比如: <button id="btn">按钮</bu ...
- Visual Studio Team Services使用教程【1】:邀请团队成员
2017.4.23之后建议朋友看下面的帖子 TFS2017 & VSTS 实战(繁体中文视频) Visual Studio Team Services(VSTS)与敏捷开发ALM实战关键报告( ...
- C++中 =default 和 =delete 使用
编译器默认为一个类生成的默认函数 默认构造函数 默认析构函数 默认拷贝构造函数 默认赋值函数 移动构造函数 移动拷贝函数 class DataOnly { public: DataOnly () // ...
- C++中常量成员函数的含义
C++中常量成员函数的含义 本文内容来源:<C++必知必会> 使用常量成员函数可以改变对象的逻辑状态,虽然对象的物理状态没有发生改变.考虑如下代码,它定义了一个类X: class X{ p ...
- Linux 2>&1的意思
2>&1的意思是将标准错误(2)也定向到标准输出(1)的输出文件中. 我们来具体了解下:Linux 中三种标准输入输出,分别是STDIN,STDOUT,STDERR,对应的数字是0,1, ...
- TCP/IP||动态选路
1.动态选路 动态选路协议用于路由器之间的通信,当相邻路由器之间进行通信,已告知对方每个路由器当前所连接的网络,就产生了动态选路,在Internet之间采用了许多不同的选路协议,Internet是以一 ...
- Java泛型类特性
在2004年末Java推出了Java5,其中提供了对泛型方法和类的支持,也围绕着泛型推出了一下特性,本章将对Java泛型进行综合的概括 1.泛型特性构件pre-Java 5 1.使用Object表示泛 ...