次小生成树模板(poj1679)
prim
#include <iostream>
#include <cstdio>
#include <cstdlib>
#include <cmath>
#include <algorithm>
#include <cstring>
#include <stack>
#include <cctype>
#include <queue>
#include <string>
#include <vector>
#include <set>
#include <map>
#include <climits>
#define lson root<<1,l,mid
#define rson root<<1|1,mid+1,r
#define fi first
#define se second
#define ping(x,y) ((x-y)*(x-y))
#define mst(x,y) memset(x,y,sizeof(x))
#define mcp(x,y) memcpy(x,y,sizeof(y))
#define Min(x,y) (x<y?x:y)
#define Max(x,y) (x>y?x:y)
using namespace std;
#define gamma 0.5772156649015328606065120 //欧拉常数
#define MOD 100000007
#define inf 0x3f3f3f3f
#define N 205
#define maxn 10001000
typedef long long LL;
typedef pair<int,int> PII; int vis[],d[],pic[][],used[][],path[][];
int ans,n,pre[]; int prim()
{
for(int i=; i<=n; ++i) pre[i]=;
mst(vis,);
vis[]=;
int res=;
int i,j;
for(i=; i<=n; ++i) d[i]=pic[][i];
for(i=; i<n; ++i)
{
int m=inf,u;
for(j=; j<=n; ++j)
if(!vis[j]&&d[j]<m)
m=d[u=j];
res+=m;
vis[u]=;
used[u][pre[u]]=used[pre[u]][u]=;
for(j=; j<=n; ++j)
if(!vis[j]&&pic[u][j]<d[j])
{d[j]=pic[u][j];pre[j]=u;}
else if(vis[j]&&j!=u)
path[j][u]=path[u][j]=Max(m,path[j][pre[u]]);
}
int temp=inf;
for(int i=; i<=n; ++i)
for(int j=i+; j<=n; ++j)
{
if(!used[i][j])
temp=Min(temp,res+pic[i][j]-path[i][j]);
}
if(temp==res) return ;
ans=res;
return ;
} int main()
{
//freopen("in.txt","r",stdin);
int i,j,x,y,v,group,m;
scanf("%d",&group);
while(group--)
{
scanf("%d%d",&n,&m);
mst(path,);
mst(pic,inf);
mst(used,);
for(i=; i<m; ++i)
{
scanf("%d%d%d",&x,&y,&v);
pic[x][y]=pic[y][x]=v;
}
ans=;
if(prim()) printf("%d\n",ans);
else printf("Not Unique!\n");
}
return ;
}
kruskal:
#include <iostream>
#include <cstdio>
#include <cstdlib>
#include <cmath>
#include <algorithm>
#include <cstring>
#include <stack>
#include <cctype>
#include <queue>
#include <string>
#include <vector>
#include <set>
#include <map>
#include <climits>
#define lson root<<1,l,mid
#define rson root<<1|1,mid+1,r
#define fi first
#define se second
#define ping(x,y) ((x-y)*(x-y))
#define mst(x,y) memset(x,y,sizeof(x))
#define mcp(x,y) memcpy(x,y,sizeof(y))
#define Min(x,y) (x<y?x:y)
#define Max(x,y) (x>y?x:y)
using namespace std;
#define gamma 0.5772156649015328606065120
#define MOD 100000007
#define inf 0x3f3f3f3f
#define N 100005
#define maxn 1000050
typedef long long LL;
typedef pair<int,int> PII; int n,m,cnt,vis[6000],fp[105]; ///vis[]是标记第一次求mst时用过哪些边(后面枚举删边时用到)
struct Node{
int x,y,v;
bool operator<(const Node&a)const{
return v<a.v;
}
Node(){}
Node(int a,int b,int c):x(a),y(b),v(c){}
}node[6000];
int findp(int x){return fp[x]==x?x:fp[x]=findp(fp[x]);} int kus(int xx){ ///xx表示删除哪条边
int res=0;
for(int i=0;i<=n;++i)fp[i]=i;
int num=1;
for(int i=0;i<cnt;++i){
if(i==xx)continue;
int x=findp(node[i].x);
int y=findp(node[i].y);
if(x==y)continue;
res+=node[i].v;
fp[x]=y;
if(xx==inf)vis[i]=1;
if(++num==n)break;
}
if(num<n)return inf;
else return res;
} int main(){
int x,y,v,i,j,group,Case=0,m;
//freopen("in.txt","r",stdin);
scanf("%d",&group);
while(group--){
mst(vis,0);
scanf("%d%d",&n,&m);
cnt=0;
while(m--){
scanf("%d%d%d",&x,&y,&v);
node[cnt++]=Node(x,y,v);
}
sort(node,node+cnt);
int res=kus(inf),ans=inf;
for(i=0;i<cnt;++i){
if(vis[i])
ans=Min(ans,kus(i));
}
if(ans==res)printf("Not Unique!\n");
else printf("%d\n",res);
}
return 0;
}
次小生成树模板(poj1679)的更多相关文章
- poj 2831 次小生成树模板
/*次小生成树 题意:给你一些路径,现在将一部分路径权值减少后问是否可以替代最小生成树里面的边. 解:次小生成树,即将这条边连上,构成一个环 求出任意两点路径之间的除了这条边的最大值,比较这个最大值& ...
- poj1679The Unique MST(次小生成树模板)
次小生成树模板,别忘了判定不存在最小生成树的情况 #include <iostream> #include <cstdio> #include <cstring> ...
- POJ-1679 The Unique MST,次小生成树模板题
The Unique MST Time Limit: 1000MS Memory Limit: 10000K Description Given a connected undirec ...
- POJ_1679_The Unique MST(次小生成树模板)
The Unique MST Time Limit: 1000MS Memory Limit: 10000K Total Submissions: 23942 Accepted: 8492 D ...
- poj 1679 The Unique MST (次小生成树模板题)
Given a connected undirected graph, tell if its minimum spanning tree is unique. Definition 1 (Spann ...
- 次小生成树(poj1679)
The Unique MST Time Limit: 1000MS Memory Limit: 10000K Total Submissions: 20737 Accepted: 7281 D ...
- POJ 1679 The Unique MST 【最小生成树/次小生成树模板】
The Unique MST Time Limit: 1000MS Memory Limit: 10000K Total Submissions: 22668 Accepted: 8038 D ...
- uva10600次小生成树模板题
裸题,上模板就行,注意j ! = k #include<map> #include<set> #include<cmath> #include<queu ...
- POJ -1679(次小生成树)模板
The Unique MST Time Limit: 1000MS Memory Limit: 10000K Total Submissions:34617 Accepted: 12637 D ...
随机推荐
- 倍福TwinCAT(贝福Beckhoff)应用教程12.1 TwinCAT控制松下伺服 连接和试运行
首先是用松下伺服自带的软件可以测试运行(驱动器,电机都连接好,然后用USB线连接到松下伺服驱动器的X1口),打开调试软件会自动提示连接到伺服 一般需要对驱动器清除绝对值编码器数据(驱动器可能报错4 ...
- 使用Unity3D的50个技巧:Unity3D最佳实践
转自:http://www.tuicool.com/articles/buMz63I 刚开始学习unity3d时间不长,在看各种资料.除了官方的手册以外,其他人的经验也是非常有益的.偶尔看到老外这篇 ...
- lodash 工具库
lodash是一套工具库,内部封装了很多字符串.数组.对象等常见数据类型的处理函数. 1.lodash的引用 import _ from 'lodash' 用一个数组遍历来说明为什么要使用lodash ...
- Objective-C(十七、KVC键值编码及实例说明)——iOS开发基础
结合之前的学习笔记以及參考<Objective-C编程全解(第三版)>,对Objective-C知识点进行梳理总结.知识点一直在变,仅仅是作为參考,以苹果官方文档为准~ 十七.键值编码 K ...
- tomcat 输入localhost:8080显示404 (找不到tomcat主页)
最近使用tomcat时常出现一个问题,tomcat开启后浏览器输入localhost:8080时显示404,但是输入项目的路径是可以看到效果的,因为没啥大碍,所以没有在意 [ 在这里顺便介绍几种访问 ...
- msbuild,Build failed with Error MSB3073 exited with code 1
1. 接手以前的老项目,因为项目比较大,所以用Developer Command Prompt 的msbuild命令编译比较快一些,常用命令如下 devenv /? 帮助 ms ...
- [DevExpress]XtraTabControl右键加入关闭当前页、关闭其它页、所有关闭的实现
private void xtraTabControl_MouseDown(object sender, MouseEventArgs e) { if (e.Button == MouseButton ...
- vue 跨域:使用vue-cli 配置 proxyTable 实现跨域问题
路径在/config/index.js 中,找到dev.proxyTable.如下配置示例: proxyTable: { '/api': { // 我要请求的地址 target: 'http://oa ...
- Xilinx FPGA 学习笔记
一.时序设计 方法1.通过状态机来实现,通过verilog控制FPGA,让它该快的时候快,该慢的时候慢. 方法2.FPGA中运行CPU 把逻辑控制顺序复杂的事情用C代码来实现,而实时处理部分用veri ...
- java - day15 - nstInner
匿名内部类 package com.javatest.mama; public class Mama { int x = 5; public static void main(String[] arg ...