POJ - 3164-Command Network 最小树形图——朱刘算法

时间:2022-11-09 18:35:05

POJ - 3164

题意: 一个有向图,存在从某个点为根的,可以到达所有点的一个最小生成树,则它就是最小树形图。

  题目就是求这个最小的树形图。

参考资料:https://blog.csdn.net/txl199106/article/details/62045479

#include <iostream>
#include <cstdio>
#include <algorithm>
#include <cstring>
#include <string>
#include <vector>
#include <map>
#include <set>
#include <queue>
#include <list>
#include <cstdlib>
#include <iterator>
#include <cmath>
#include <iomanip>
#include <bitset>
#include <cctype>
using namespace std;
//#pragma comment(linker, "/STACK:102400000,102400000") //c++
#define lson (l , mid , rt << 1)
#define rson (mid + 1 , r , rt << 1 | 1)
#define debug(x) cerr << #x << " = " << x << "\n";
#define pb push_back
#define pq priority_queue typedef long long ll;
typedef unsigned long long ull; typedef pair<ll ,ll > pll;
typedef pair<int ,int > pii; //priority_queue<int> q;//这是一个大根堆q
//priority_queue<int,vector<int>,greater<int> >q;//这是一个小根堆q
#define fi first
#define se second
#define endl '\n' #define OKC ios::sync_with_stdio(false);cin.tie(0);cout.tie(0)
#define FT(A,B,C) for(int A=B;A <= C;++A) //用来压行
#define REP(i , j , k) for(int i = j ; i < k ; ++i)
//priority_queue<int ,vector<int>, greater<int> >que; const ll mos = 0x7FFFFFFF; //
const ll nmos = 0x80000000; //-2147483648
const int inf = 0x3f3f3f3f; template<typename T>
inline T read(T&x){
x=;int f=;char ch=getchar();
while (ch<''||ch>'') f|=(ch=='-'),ch=getchar();
while (ch>=''&&ch<='') x=x*+ch-'',ch=getchar();
return x=f?-x:x;
}
// #define _DEBUG; //*//
#ifdef _DEBUG
freopen("input", "r", stdin);
// freopen("output.txt", "w", stdout);
#endif
/*-----------------show time----------------*/ int n,m; struct nn
{
int x,y;
}a[]; struct node
{
int u,v;
double dis;
}e[];
double get(int i,int j){
return sqrt((a[i].x-a[j].x)*(a[i].x-a[j].x) + (a[i].y-a[j].y)*(a[i].y-a[j].y));
} double in[];
int id[],vis[];
int pre[];
int flag = ;
double zhuliu(int root){
double ans = 0.0;
while(true){
for(int i=; i<=n; i++){
in[i] = 9999999999.99;
} for(int i=; i<=m; i++){
node & b = e[i];
if(b.u!=b.v && in[b.v] > e[i].dis){
in[b.v] = e[i].dis;
pre[b.v] = b.u;
}
} for(int i=; i<=n; i++){
if(i!=root&&in[i]>=9999999999.99){
flag = ;
return -;
}
} memset(id,-,sizeof(id));
memset(vis,-,sizeof(vis));
in[root] = ; int num = ;
for(int i=; i<=n; i++){
ans += in[i];
// debug(ans);
int v = i;
while(vis[v]!=i && v!=root&&id[v]==-){
vis[v] = i;
v = pre[v];
}
if(v!=root&&id[v] ==-){
for(int u=pre[v] ; u!=v; u = pre[u]){
id[u] = num;
}
id[v]=num++;
}
}
if(num==)break; for(int i=; i<=n; i++){
if(id[i] == -){
id[i]=num++;
}
} for(int i=; i<=m; i++){
int v = e[i].v; e[i].u = id[e[i].u];
e[i].v = id[e[i].v];
if(e[i].u!=e[i].v)
e[i].dis = e[i].dis - in[v];
}
n = num-;
root = id[root];
}
return ans;
} int main(){
while(~scanf("%d%d", &n, &m)){
for(int i=; i<=n; i++){
scanf("%d%d", &a[i].x, &a[i].y);
} for(int i=; i<=m; i++){
scanf("%d%d", &e[i].u, &e[i].v);
e[i].dis = get(e[i].u, e[i].v);
}
flag = ;
double tmp = zhuliu();
if(flag==)puts("poor snoopy");
else printf("%.2f\n",tmp);
} return ;
}

POJ-3164

POJ - 3164-Command Network 最小树形图——朱刘算法的更多相关文章

  1. POJ 3164 Command Network 最小树形图 朱刘算法

    =============== 分割线之下摘自Sasuke_SCUT的blog============= 最 小树形图,就是给有向带权图中指定一个特殊的点root,求一棵以root为根的有向生成树T, ...

  2. POJ 3164 Command Network 最小树形图

    题目链接: 题目 Command Network Time Limit: 1000MS Memory Limit: 131072K 问题描述 After a long lasting war on w ...

  3. POJ 3164 Command Network 最小树形图模板

    最小树形图求的是有向图的最小生成树,跟无向图求最小生成树有很大的区别. 步骤大致如下: 1.求除了根节点以外每个节点的最小入边,记录前驱 2.判断除了根节点,是否每个节点都有入边,如果存在没有入边的点 ...

  4. 最小树形图——朱刘算法&lpar;Edmonds&rpar;

    定义:一个有向图,存在从某个点为根的,可以到达所有点的一个最小生成树,则它就是最小树形图. 朱刘算法实现过程: [在选出入边集后(看步骤1),若有向图中不存在有向环,说明该图就是最小树形图] 1,选入 ...

  5. POJ 3164 Command Network ( 最小树形图 朱刘算法)

    题目链接 Description After a long lasting war on words, a war on arms finally breaks out between littlek ...

  6. poj3164&lpar;最小树形图&amp&semi;朱刘算法模板&rpar;

    题目链接:http://poj.org/problem?id=3164 题意:第一行为n, m,接下来n行为n个点的二维坐标, 再接下来m行每行输入两个数u, v,表点u到点v是单向可达的,求这个有向 ...

  7. 最小树形图--朱刘算法&lpar;&lbrack;JSOI2008&rsqb;小店购物&rpar;

    题面 luogu Sol 首先设一个 \(0\) 号点,向所有点连边,表示初始价值 显然这个图的一个 \(0\) 为根的最小有向生成树的边权和就是每个买一次的最小价值 再买就一定能优惠(包含 \(0\ ...

  8. 洛谷P4716 【模板】最小树形图&lpar;朱刘算法&rpar;

    题意 题目链接 Sol 朱刘算法?感觉又是一种神仙贪心算法 大概就是每次贪心的用每个点边权最小的入边更新答案,如果不行的话就缩起来找其他的边 不详细说了,丢链接走人.. #include<bit ...

  9. bzoj 4349 最小树形图——朱刘算法

    题目:https://www.lydsy.com/JudgeOnline/problem.php?id=4349. 学习博客:http://www.cnblogs.com/xzxl/p/7243466 ...

随机推荐

  1. Web API与文件操作

    前段时间,一直有练习ASP.NET MVC与Web API交互,接下来,Insus.NET再做一些相关的练习,Web API与文件操作,如POST文件至Web API,更新或是删除等. 不管怎样,先在 ...

  2. freebsd 系统时间

    http://blog.csdn.net/wowoto/article/details/5557810 https://www.douban.com/note/150233427/ date #查看当 ...

  3. &lbrack;Aaronyang&rsqb; 写给自己的WPF4&period;5 笔记&lbrack;2依赖属性&rsqb;

    人生的意义不在于拿一手好牌,而在于打好一手坏牌 --Aaronyang的博客(www.ayjs.net)-www.8mi.me =============时隔两年后再看WPF========== 因为 ...

  4. Duilib动画按钮实现&lpar;转载&rpar;

    转载:http://blog.csdn.net/cuiguanghui123/article/details/51674218 .h文件 #ifndef __UIBUTTONEX_H__ #defin ...

  5. Maven&plus;Spring&plus;MVC结构中,jetty&sol;tomcat是如何启动项目的&lbrack;转&rsqb;

    针对maven配置的Spring+MVC项目,我们用Maven自带的jetty和tomcat插件进行调试,这很方便.但是调试时,这些插件所启动的web服务器,是如何来将我们的工程作为一个web项目启动 ...

  6. Mybatis全部查询遇到的返回类型的小问题

    在学习Mybatis3过程中遇到一个小问题,觉得需要注意就把它写下来了 在查询所有数据的时候方法是这样的 public List<User> findAll(){ ..... } 在它的u ...

  7. apache &lpar;order allow&comma;deny or deny&comma;allow&rpar;

    平台:"rhel6.2" 实验内容: "测试apache‘order allow,deny’ or ‘order deny,allow’ 功能" 配置文件:&q ...

  8. 时间函数DateTime&lpar;&rpar;的用法

    //2008年4月24日 System.DateTime.Now.ToString("D"); //2008-4-24 System.DateTime.Now.ToString(& ...

  9. SQL基础-----DML语句

    之前已经介绍过SQL基础之DDL(数据库定义语言)语句,http://www.cnblogs.com/cxq0017/p/6433938.html(这是地址) 这篇文章主要介绍DML语句(数据库操纵语 ...

  10. &lpar;oralce&rpar;pga&lowbar;aggregate&lowbar;target与workarea&lowbar;size&lowbar;policy相互关系验证

    pga_aggregate_target与workarea_size_policy相互关系验证 先放上结论: 1. 当pga_aggregate_target设置为非0, 手工设置(workarea ...