题目链接:http://www.lydsy.com/JudgeOnline/problem.php?id=1083 由kruskal算法原理可知,我们对一张无向图做普通的最小生成树,连上的最后一条边就是答案. #include<cstdio> #include<cstring> #include<algorithm> using namespace std; int inline readint(){ int Num;char ch; '; +ch-'; return…
我也不知道为什么我要来写这个-怕是写水题写上瘾了(bu #include<cstdio> #include<algorithm> #define rep(i,n) for(register int i=1;i<=n;i++) const int N=10005; struct edge { int u,v,c; }e[N]; int n,m,mx,s[N],pre[N]; inline int find(int x){return pre[x]==x?x:find(pre[x…
Bzoj 1083: [SCOI2005]繁忙的都市 题目链接:https://www.lydsy.com/JudgeOnline/problem.php?id=1083 此题是最小瓶颈生成树的裸题. 最小瓶颈生成树:由最小的边权的\(n-1\)条边连接起\(n\)个点. 显然这就是\(Kruskal\)算法.继而得知其实就是求最小生成树,用\(prim\)也可以求. 然后这道题就成了最小生成树入门题?? #include <algorithm> #include <iostream&g…
本意是求最小瓶颈生成树,但是我们可以证明:最小生成树也是最小瓶颈生成树(其实我不会).数据范围很小,暴力kruscal即可. #include<cstdio> #include<algorithm> using namespace std; ]; bool operator < (const Edge &a,const Edge &b){return a.w<b.w;} ],rank[],tot; ;i<=n;i++)fa[i]=i;} int f…
水题之王SP…这题就裸的最小生成树 /************************************************************** Problem: 1083 User: zhuohan123 Language: C++ Result: Accepted Time:32 ms Memory:1404 kb ****************************************************************/ #include <iost…
Description 城市C是一个非常繁忙的大都市,城市中的道路十分的拥挤,于是市长决定对其中的道路进行改造.城市C的道路是这样分布的:城市中有n个交叉路口,有些交叉路口之间有道路相连,两个交叉路口之间最多有一条道路相连接.这些道路是双向的,且把所有的交叉路口直接或间接的连接起来了.每条道路都有一个分值,分值越小表示这个道路越繁忙,越需要进行改造.但是市政府的资金有限,市长希望进行改造的道路越少越好,于是他提出下面的要求: 1. 改造的那些道路能够把所有的交叉路口直接或间接的连通起来. 2.…
链接:https://www.lydsy.com/JudgeOnline/problem.php?id=1083 思路:连接所有点,肯定最少是需要n-1条边的,也就是写个最小生成树,记得保存下最大的权值就好了 实现代码: #include<bits/stdc++.h> using namespace std; ; int f[M],cnt; struct node{ int u,v,w; }e[]; bool cmp(node a,node b){ return a.w < b.w; }…
https://www.lydsy.com/JudgeOnline/problem.php?id=1083 题意:给你一个图,求生成树最大边权最小值 就是求瓶颈生成树(生成树中最大边权最小),最小生成树一定是瓶颈生成树,但是瓶颈生成树不一定是最小生成树,最小瓶颈生成树一定是最小生成树 /************************************************************** Problem: 1083 User: walfy Language: C++ Res…
题目链接 Solution 裸的最小生成树. Code #include<bits/stdc++.h> using namespace std; const int maxn=500008; struct sj{int to,fr,w;}a[maxn]; bool cmp(sj x,sj y) {return x.w<y.w;} int n,fa[maxn],ans,m; int find(int x) {if(x==fa[x])return x;else return fa[x]=fi…
[BZOJ1083][SCOI2005]繁忙的都市(最小生成树) 题面 BZOJ 洛谷 题解 模板题. #include<iostream> #include<cstdio> #include<algorithm> using namespace std; #define MAX 350 #define MAXL 10100 inline int read() { int x=0;bool t=false;char ch=getchar(); while((ch<…