poj 3164 Command Network (朱刘算法)
题目链接:
http://poj.org/problem?id=3164
题目大意:
有n个点(用坐标表示)各点编号分别为1—>n,m条单向路,问能否存在一个花费价值最小的网络,能使从1点到达任一个点。
解题思路:
很明显的朱刘模板题,但是刚看到这个题目的时候,弱还不懂这个东西%>_<%
最小树形图就是给有向带权图中指定一个特殊的点root,求一棵以root为根的有向生成树T,并且T中所有边的总权值最小。
朱刘算法:当有向图中不存在自环,为除根之外的每个点选定一条入边,这条入边一定要是所有入边中最小的。所有的最小入边都选择出来了,如果这个入边集不存在有向环的话,这个集合就是该图的最小树形图。如果有自环的话就要消除自环,比如,现在我们假设分别有3-->1,权值为1 . 1-->3,权值为2 . 2-->1,权值为6 . 4-->3,权值为5. ,root为点4,存在自环1-->3-->1,现在就需要把1,3缩成一个点,则需要把4-->3边的权值5-2,2-->1边的权值变为6-1,。
#include <cmath>
#include <cstdio>
#include <cstring>
#include <iostream>
#include <algorithm>
using namespace std;
const int maxn = ;
const int N = ;
const double Exp = 1e-;
const int INF = 0x3f3f3f3f;
struct Point
{
double x, y;
double length(Point a)
{
return sqrt((a.x-x)*(a.x-x)+(a.y-y)*(a.y-y));
}
}; struct Edge
{
int u, v;
double w;
}; Point point[maxn];
Edge edge[N];
int n, m;
double directed_MST (int root)
{
double pre[maxn], ans = ;
//pre[i]为到i点权值最小的边值
int vis[maxn], id[maxn], pr[maxn];
//vis[i]为i点是否在当前的数上,id[i]为i点是否在自环内,
int u, v;
while (true)
{
for (int i=; i<=n; i++)
pre[i] = INF;
for (int i=; i<m; i++)
{
u = edge[i].u;
v = edge[i].v;
if (edge[i].w<pre[v] && u!=v)
{
pre[v] = edge[i].w;
pr[v] = u;//到v点前驱
}
}
for (int i=; i<=n; i++)
{
if (i == root)
continue;
if (pre[i] == INF)
return -;//没有点与i相连,不存在最小树形图
}
memset (vis, -, sizeof(vis));
memset (id, -, sizeof(id));
int cru = ;//对现存的点从新编号
pre[root] = ;
for (int i=; i<=n; i++)
{
ans += pre[i];
v = i;
while (vis[v]!=i && id[v]==- && v!=root)
{//向树上加点
vis[v] = i;
v = pr[v];
}
if (v!=root && id[v]==-)
{//存在自环,并且把环变成一个点
for (u=pr[v]; u!=v; u=pr[u])
id[u] = cru;
id[u] = cru ++;
}
}
if (cru == )
break;//不存在自环
for (int i=; i<=n; i++)
if (id[i] == -)
id[i] = cru ++;//对不在自环上的点编号
for (int i=; i<m; i++)
{//把自环缩成一个点后,需要改变边的权
u = edge[i].u;
v = edge[i].v;
edge[i].u = id[u];
edge[i].v = id[v];
if (id[u] != id[v])
edge[i].w -= pre[v];
}//缩点后点数改变,根节点改变
n = cru - ;
root = id[root];
}
return ans;
}
int main ()
{
while (scanf ("%d %d", &n, &m) != EOF)
{
for (int i=; i<=n; i++)
scanf ("%lf %lf", &point[i].x, &point[i].y); for (int i=; i<m; i++)
{
int u, v;
scanf ("%d %d", &u, &v);
edge[i].u = u;
edge[i].v = v;
if (u == v)
edge[i].w = INF;
else
edge[i].w = point[u].length(point[v]);
}
double num = directed_MST();
if (num+< Exp)
printf ("poor snoopy\n");
else
printf ("%.2f\n", num);
}
return ;
}
poj 3164 Command Network (朱刘算法)的更多相关文章
- POJ 3164 Command Network ( 最小树形图 朱刘算法)
题目链接 Description After a long lasting war on words, a war on arms finally breaks out between littlek ...
- POJ 3164 Command Network 最小树形图 朱刘算法
=============== 分割线之下摘自Sasuke_SCUT的blog============= 最 小树形图,就是给有向带权图中指定一个特殊的点root,求一棵以root为根的有向生成树T, ...
- POJ 3164——Command Network——————【最小树形图、固定根】
Command Network Time Limit: 1000MS Memory Limit: 131072K Total Submissions: 15080 Accepted: 4331 ...
- POJ 3164 Command Network (最小树形图)
[题目链接]http://poj.org/problem?id=3164 [解题思路]百度百科:最小树形图 ]里面有详细的解释,而Notonlysucess有精简的模板,下文有对其模板的一点解释,前提 ...
- POJ 3164 Command Network 最小树形图
题目链接: 题目 Command Network Time Limit: 1000MS Memory Limit: 131072K 问题描述 After a long lasting war on w ...
- poj 3164 Command Network(最小树形图模板)
Command Network http://poj.org/problem?id=3164 Time Limit: 1000MS Memory Limit: 131072K Total Subm ...
- POJ 3164 Command Network(最小树形图模板题+详解)
http://poj.org/problem?id=3164 题意: 求最小树形图. 思路: 套模板. 引用一下来自大神博客的讲解:http://www.cnblogs.com/acjiumeng/p ...
- poj 3164 Command Network
http://poj.org/problem?id=3164 第一次做最小树形图,看着别人的博客写,还没弄懂具体的什么意思. #include <cstdio> #include < ...
- POJ 3164 Command Network 最小树形图模板
最小树形图求的是有向图的最小生成树,跟无向图求最小生成树有很大的区别. 步骤大致如下: 1.求除了根节点以外每个节点的最小入边,记录前驱 2.判断除了根节点,是否每个节点都有入边,如果存在没有入边的点 ...
随机推荐
- Maven创建项目时出现Generating project in Interactive mode就一直卡住的解决方案
使用maven命令在创建项目的时候出现 Generating project in Interactive mode 然后就一直卡住 网上搜做了很多解决方案 有说各种方案的,最后找到了一种.实验成功 ...
- 【stl学习笔记】set、multiset
set和multiset会根据特定的排序准则,自动将元素排序.两者不同处在于multiset允许元素重复而set不允许 在使用set或multiset之前,必须先加入头文件<set> se ...
- Office EXCEL 中如何让一个单元格的数据链接到另一个工作表的数据
比如我在Sheet2中定义了几个数据,这些都是简单的数字,而在Sheet1中让要被绑定的单元格等于Sheet2的对应单元格地址(比如Sheet2!B1,Sheet2!B2之类的) 然后就可以一改全 ...
- 解决UnicodeDecodeError: 'ascii' codec can't decode byte 0xe7 in position 12: ordinal not in range(128)的编码问题
当我在运行一个基于scrapy的爬虫时出现UnicodeDecodeError: 'ascii' codec can't decode byte 0xe7 in position 12: ordina ...
- python 【第三篇】函数基础
深浅拷贝 set是一个无序且不重复的元素集合访问速度快天生解决重复问题 #!/usr/bin/env python3 # -*- coding:utf-8 -*- #深浅拷贝 import copy ...
- 关于java及多线程
http://www.w3cschool.cc/java/java-multithreading.html
- 反混淆、反编译unity3d动画插件DFTweenLite得到源代码
出处:http://blog.csdn.net/u010019717 author:孙广东 时间:2015.3.17 23:00 我为什么要得到这个源代码.由于有洁癖! 对于Itween ...
- js可视区域图片懒加载
可视区域图片懒加载 实现原理,页面滚动时获取需要懒加载的图片,判断此图片是否在可视区域内,是则设置图片data-src地址为src地址,加载图片. html下载地址 <!DOCTYPE html ...
- [英语学习]王秒同学《21天TED英语精练团》
第一个分享: Chris Anderson的TED's secret to great public speaking(英音). There's no single formula for a gre ...
- 怎样快速刪除Word中超链接?
有时我们从网上down了一些资料,存到Word文档里,会发现一些文字和图片带有超链接.这其实是Word自动修改功能引起的麻烦,那么,有什么办法可以把这些超链接快速批量删掉吗? 步骤/方法 1 按键盘上 ...