bzoj 1083: [SCOI2005]繁忙的都市

 1 #include<cstdio>
 2 #include<iostream>
 3 #include<algorithm>
 4 #define M 10005
 5 using namespace std;
 6 struct data
 7 {
 8     int u,v,w;
 9 }a[M];
10 int n,m,fa[M],sum;
11 bool cmp(data a1,data a2)
12 {
13     return a1.w<a2.w;
14 }
15 int find(int a1)
16 {
17     if(fa[a1]==a1)
18       return a1;
19     fa[a1]=find(fa[a1]);
20     return fa[a1];
21 }
22 int main()
23 {
24     scanf("%d%d",&n,&m);
25     for(int i=1;i<=m;i++)
26       scanf("%d%d%d",&a[i].u,&a[i].v,&a[i].w);
27     sort(a+1,a+m+1,cmp);
28     for(int i=1;i<=n;i++)
29       fa[i]=i;
30     for(int i=1;i<=m;i++)
31       {
32         int q1=find(a[i].u),q2=find(a[i].v);
33         if(q1!=q2)
34           {
35             fa[q1]=q2;
36             sum=a[i].w;
37             }
38       }
39     printf("%d %d",n-1,sum);
40     return 0;
41 }

很显然题目描述就是求一个最小生成树

时间: 2024-10-09 06:05:33

bzoj 1083: [SCOI2005]繁忙的都市的相关文章

BZOJ 1083: [SCOI2005]繁忙的都市(MST)

裸的最小生成树..直接跑就行了 ---------------------------------------------------------------------- #include<cstdio> #include<algorithm> #include<vector> #define rep(i,n) for(int i=0;i<n;i++) #define addEdge(u,v,w) MST.edges.push_back((KRUSKAL::Ed

BZOJ 1083: [SCOI2005]繁忙的都市【Kruscal最小生成树裸题】

1083: [SCOI2005]繁忙的都市 Time Limit: 10 Sec  Memory Limit: 162 MBSubmit: 2925  Solved: 1927[Submit][Status][Discuss] Description 城市C是一个非常繁忙的大都市,城市中的道路十分的拥挤,于是市长决定对其中的道路进行改造.城市C的道 路是这样分布的:城市中有n个交叉路口,有些交叉路口之间有道路相连,两个交叉路口之间最多有一条道路相连 接.这些道路是双向的,且把所有的交叉路口直接或

BZOJ 1083: [SCOI2005]繁忙的都市 裸的最小生成树

题目链接: http://www.lydsy.com/JudgeOnline/problem.php?id=1083 代码: #include<iostream> #include<cstdio> #include<algorithm> using namespace std; const int maxn = 333; const int maxm = maxn*maxn; struct Edge { int u, v, w; bool operator < (

bzoj 1083: [SCOI2005]繁忙的都市 (最小生成树)

链接:https://www.lydsy.com/JudgeOnline/problem.php?id=1083 思路:连接所有点,肯定最少是需要n-1条边的,也就是写个最小生成树,记得保存下最大的权值就好了 实现代码: #include<bits/stdc++.h> using namespace std; const int M = 3e4+10; int f[M],cnt; struct node{ int u,v,w; }e[100010]; bool cmp(node a,node

1083: [SCOI2005]繁忙的都市

---恢复内容开始--- 1083: [SCOI2005]繁忙的都市 Time Limit: 10 Sec  Memory Limit: 162 MBSubmit: 1611  Solved: 1040[Submit][Status][Discuss] Description 城市C是一个非常繁忙的大都市,城市中的道路十分的拥挤,于是市长决定对其中的道路进行改造.城市C的道路是这样分布的:城市中有n个交叉路口,有些交叉路口之间有道路相连,两个交叉路口之间最多有一条道路相连接.这些道路是双向的,且

Bzoj1083 1083: [SCOI2005]繁忙的都市【MST】

大水题,真不知道出题者是怎么把这么水的题出的这么长的TAT 其实这题在于考语文水平,一共三个要求,前两个要求意思就是要选出的道路是树形的,最后一个要求就是要权值最小,于是整个题意说白了就是求一棵MST,以前向星的形式给出最容易想到kruskal算法,于是这题顺利结束,从看题一直到调试结束半个小时搞定…… #include<iostream> #include<cstdio> #include <math.h> using namespace std; intfather

BZOJ 1083:[SCOI2005]繁忙的都市(最小生成树)

1083: [SCOI2005]繁忙的都市 Description 城市C是一个非常繁忙的大都市,城市中的道路十分的拥挤,于是市长决定对其中的道路进行改造.城市C的道路是这样分布的:城市中有n个交叉路口,有些交叉路口之间有道路相连,两个交叉路口之间最多有一条道路相连接.这些道路是双向的,且把所有的交叉路口直接或间接的连接起来了.每条道路都有一个分值,分值越小表示这个道路越繁忙,越需要进行改造.但是市政府的资金有限,市长希望进行改造的道路越少越好,于是他提出下面的要求: 1. 改造的那些道路能够把

bzoj1083: [SCOI2005]繁忙的都市(最小生成树)

1083: [SCOI2005]繁忙的都市 题目:传送门 题解: 一道大水题: 第一问明显输出n-1 第二问最小生成树 秒切 代码: 1 #include<cstdio> 2 #include<cstring> 3 #include<cstdlib> 4 #include<cmath> 5 #include<algorithm> 6 using namespace std; 7 struct node 8 { 9 int x,y,c; 10 }a

BZOJ1083: [SCOI2005]繁忙的都市

传送门:http://www.lydsy.com/JudgeOnline/problem.php?id=1083 题目大意:城市C是一个非常繁忙的大都市,城市中的道路十分的拥挤,于是市长决定对其中的道路进行改造.城市C的道 路是这样分布的:城市中有n个交叉路口,有些交叉路口之间有道路相连,两个交叉路口之间最多有一条道路相连 接.这些道路是双向的,且把所有的交叉路口直接或间接的连接起来了.每条道路都有一个分值,分值越小表示这 个道路越繁忙,越需要进行改造.但是市政府的资金有限,市长希望进行改造的道