uva10600次小生成树模板题
裸题,上模板就行,注意j ! = k
#include<map>
#include<set>
#include<cmath>
#include<queue>
#include<stack>
#include<vector>
#include<cstdio>
#include<cassert>
#include<iomanip>
#include<cstdlib>
#include<cstring>
#include<iostream>
#include<algorithm>
#define pi acos(-1)
#define ll long long
#define mod 1000000007
#define ls l,m,rt<<1
#define rs m+1,r,rt<<1|1
#pragma comment(linker, "/STACK:1024000000,1024000000") using namespace std; const double g=10.0,eps=1e-;
const int N=+,maxn=,inf=0x3f3f3f; int c[N][N],d[N],pre[N],n;
int maxx[N][N];
bool vis[N],used[N][N];
int prim()
{
memset(vis,,sizeof vis);
memset(used,,sizeof used);
memset(maxx,,sizeof maxx);
for(int i=;i<=n;i++)
{
pre[i]=;
d[i]=c[][i];
}
vis[]=;
pre[]=;
d[]=;
int ans=;
for(int i=;i<=n;i++)
{
int mind=inf,k;
for(int j=;j<=n;j++)
{
if(!vis[j]&&mind>d[j])
{
mind=d[j];
k=j;
}
}
vis[k]=;
ans+=mind;
used[k][pre[k]]=used[pre[k]][k]=;
for(int j=;j<=n;j++)
{
if(vis[j]&&j!=k)maxx[j][k]=maxx[k][j]=max(maxx[j][pre[k]],d[k]);
if(!vis[j]&&d[j]>c[j][k])
{
d[j]=c[j][k];
pre[j]=k;
}
}
}
return ans;
}
int smst(int mst)
{
int ans=inf;
for(int i=;i<=n;i++)
{
for(int j=i+;j<=n;j++)
{
if(c[i][j]!=inf&&!used[i][j])
{
ans=min(ans,mst+c[i][j]-maxx[i][j]);
}
}
}
return ans;
}
int main()
{
ios::sync_with_stdio(false);
cin.tie();
int t,m;
cin>>t;
while(t--){
cin>>n>>m;
for(int i=;i<=n;i++)
{
c[i][i]=;
for(int j=i+;j<=n;j++)
c[i][j]=c[j][i]=inf;
}
while(m--){
int x,y,z;
cin>>x>>y>>z;
c[x][y]=c[y][x]=z;
}
int ans=prim();
cout<<ans<<" "<<smst(ans)<<endl;
}
return ;
}
uva10600次小生成树模板题的更多相关文章
- POJ-1679 The Unique MST,次小生成树模板题
		
The Unique MST Time Limit: 1000MS Memory Limit: 10000K Description Given a connected undirec ...
 - poj 1679 The Unique MST (次小生成树模板题)
		
Given a connected undirected graph, tell if its minimum spanning tree is unique. Definition 1 (Spann ...
 - poj-2421-最小生成树刷题
		
title: poj-2421-最小生成树刷题 date: 2018-11-20 20:30:29 tags: acm 刷题 categories: ACM-最小生成树 概述 做了几道最小生成树的题, ...
 - poj  2831 次小生成树模板
		
/*次小生成树 题意:给你一些路径,现在将一部分路径权值减少后问是否可以替代最小生成树里面的边. 解:次小生成树,即将这条边连上,构成一个环 求出任意两点路径之间的除了这条边的最大值,比较这个最大值& ...
 - poj1679The Unique MST(次小生成树模板)
		
次小生成树模板,别忘了判定不存在最小生成树的情况 #include <iostream> #include <cstdio> #include <cstring> ...
 - UVA10600 次小生成树
		
题目链接:https://vjudge.net/problem/UVA-10600 题意:叫我们求出最小生成树的边权之和 和次小生成树的边权之和. 思路:我们可以先求出最小生成树,这个不难,如果要求次 ...
 - POJ_1679_The Unique MST(次小生成树模板)
		
The Unique MST Time Limit: 1000MS Memory Limit: 10000K Total Submissions: 23942 Accepted: 8492 D ...
 - poj1679次小生成树入门题
		
次小生成树求法:例如求最小生成树用到了 1.2.4这三条边,总共5条边,那循环3次的时候,每次分别不用1.2.4求得最小生成树的MST,最小的MST即为次小生成树 如下代码maxx即求最小生成树时求得 ...
 - POJ 1679 The Unique MST 【最小生成树/次小生成树模板】
		
The Unique MST Time Limit: 1000MS Memory Limit: 10000K Total Submissions: 22668 Accepted: 8038 D ...
 
随机推荐
- Linux系统常用命令汇总
			
命令格式:命令 -选项 参数,例如:ls -la /usr:当有多个选项时,可以写在一起.ifconfig:查看当前机器的IP信息service network restart:重启网络服务servi ...
 - 20165324 《Java程序设计》第3周学习总结
			
20165324 <Java程序设计>第3周学习总结 教材学习内容总结 本周学习内容如下: 编程语言思想 面向过程语言的核心是编写解决某个问题的代码块:在面向对象语言中,最核心的内容是对象 ...
 - Code signing is required for product type 'Application' in SDK 'iOS 11.2'
			
在打包的时候出现这样一个错误,Code signing is required for product type 'Application' in SDK 'iOS 11.2' ,就是说代码签名证书 ...
 - 我的Linux病毒追踪记录
			
第一次自己一个人全权负责做游戏服务器,对于Linux安全并不太懂,所以就在昨天,服务器遭到了攻击,刚开始,只是发现服务器的带宽占满了,以为是带宽不够用,可是想想,弱联网游戏对带宽占用也不高啊而且带宽加 ...
 - SQL Server 创建游标(cursor)
			
游标的定义: 游标则是处理结果集的一种机制,它可以定位到结果集中的某一行,也可以移动游标定位到你所需要的行中进行操作数据.与 select 语句的不同是,select 语句面向的是结果集,游标面向的是 ...
 - PKU 3318 Matrix Multiplication(神奇的输入)
			
#include<cstdio> using namespace std; ][]; ][],C[][]; int Read() { ; ; while((ch=getchar())==' ...
 - 开发者不可不知的五款DIY快速开发工具,你造吗
			
对于非专业的移动开发者,弱化编程能力的快发开发工具实用性够强,无需编程只要借助工具提供的各种功能模块,就能开发出属于自己的应用,而支持DIY更能使应用开发锦上添花,借助快速开发工具开发出属于自己的“能 ...
 - ZOJ - 3229 Shoot the Bullet (有源汇点上下界最大流)
			
题意:要在n天里给m个女生拍照,每个女生有拍照数量的下限Gi,每天有拍照数量的上限Di,每天当中每个人有拍照的上限Lij和Rij.求在满足限制的基础上,所有人最大能拍多少张照片. 分析:抛开限制,显然 ...
 - 【HTML5校企公益课】第一天
			
1.搭建基本的开发环境.学校电脑用的是浏览器是Chrome,编辑器是HBuilder. 2.初步介绍HTML5的Web项目基本结构. css:样式表 img:存放图片 js:存放脚本文件 .html: ...
 - Web前端学习笔记之jQuery基础
			
0x0 jQuery介绍 jQuery是一个轻量级的.兼容多浏览器的JavaScript库. jQuery使用户能够更方便地处理HTML Document.Events.实现动画效果.方便地进行Aja ...