Problem: lab-week10-exercise02 Building a Fiber Network

Problem


Analysis

这道题看起来是最小生成树或者最短路之类的,但因为只用输出边权和,所以直接对边权排序用并查集即可,以及在用并查集的时候可以进行路径压缩降低时间复杂度。

Code

C++

cpp 复制代码
#include<iostream>
#include<cstdio>
#include<algorithm>
using namespace std;
int n,m;
int fa[100005];
int f;
bool b=1;
long long ans;

struct edge{
    int u,v,w;
}a[100005];

bool cmp(edge x,edge y){
    return x.w<y.w;
}

int find_fa(int x){
    if(fa[x]==x){
        return x;
    }
    fa[x]=find_fa(fa[x]);
    return fa[x];
}

int main(){
    cin>>n>>m;
    for(int i=1;i<=m;++i){
        cin>>a[i].u>>a[i].v>>a[i].w;
    }
    for(int i=1;i<=n;++i){
        fa[i]=i;
    }
    if(n==1){
        cout<<0<<endl;
        return 0;
    }
    if(m<n-1){
        cout<<"IMPOSSIBLE\n";
        return 0;
    }
    sort(a+1,a+m+1,cmp);
    for(int i=1;i<=m;++i){
        if(find_fa(a[i].u)!=find_fa(a[i].v)){
            ans+=1ll*a[i].w;
            fa[fa[a[i].u]]=fa[a[i].v];
        }
    }
    f=find_fa(1);
    for(int i=2;i<=n;++i){
        if(find_fa(i)!=f){
            b=0;
            break;
        }
    }
    if(b){
        cout<<ans<<endl;
    }
    else{
        cout<<"IMPOSSIBLE\n";
    }
    return 0;
}
相关推荐
D_evil__8 分钟前
【Effective Modern C++】第三章 转向现代C++:16. 让const成员函数线程安全
c++
wfeqhfxz25887821 小时前
YOLO13-C3k2-GhostDynamicConv烟雾检测算法实现与优化
人工智能·算法·计算机视觉
Aaron15881 小时前
基于RFSOC的数字射频存储技术应用分析
c语言·人工智能·驱动开发·算法·fpga开发·硬件工程·信号处理
Queenie_Charlie1 小时前
前缀和的前缀和
数据结构·c++·树状数组
kokunka2 小时前
【源码+注释】纯C++小游戏开发之射击小球游戏
开发语言·c++·游戏
_不会dp不改名_3 小时前
leetcode_3010 将数组分成最小总代价的子数组 I
算法·leetcode·职场和发展
John_ToDebug4 小时前
浏览器内核崩溃深度分析:从 MiniDump 堆栈到 BindOnce UAF 机制(未完待续...)
c++·chrome·windows
你撅嘴真丑5 小时前
字符环 与 变换的矩阵
算法
早点睡觉好了5 小时前
重排序 (Re-ranking) 算法详解
算法·ai·rag
gihigo19985 小时前
基于全局自适应动态规划(GADP)的MATLAB实现方案
算法