并查集

并查集 - yfmd - 博客园 (cnblogs.com)

xzy巨佬的博客

直接粘过来就是我的了

主要用于维护图的连通性,方便地检验冲突,防止自闭(网抑救星)等;

 

直接上个综合性比较强的例题

 

map+并查集

#include<bits/stdc++.h>
using namespace std;
namespace _mzf
{
    #define ll long long
    const ll N=1e6+100;
    ll n,cnt,t;
    map<ll,ll>f;
    struct node
    {
        ll x,y,e;
    }a[N];
    ll flag;
    ll read()
    {
        ll sum=0,flag=1;
        char ch=getchar();
        while(ch<'0'||ch>'9')
        {
            if(ch=='-') flag=-1;
            ch=getchar();
        }
        while(ch>='0'&&ch<='9')
        {
            sum=sum*10+ch-'0';
            ch=getchar();
        }
        return flag*sum;
    }
    ll find(ll x)
    {
        if(f[x]!=x) f[x]=find(f[x]);
        return f[x];
    }
    bool cmp(node a,node b)
    {
        return a.e>b.e;
    }
    void mzfmain()
    {
        t=read();
        while(t--)
        {
            n=read();
            f.clear();
            flag=0;
            for(int i=1;i<=n;i++)
            {
                a[i].x=read();
                a[i].y=read();
                a[i].e=read();
                f[a[i].x]=a[i].x;
                f[a[i].y]=a[i].y;
            }
            sort(a+1,a+1+n,cmp);
            for(int i=1;i<=n;i++)
            {
                ll s1=find(a[i].x),s2=find(a[i].y);
                if(a[i].e==1)    f[s1]=s2;
                else     if(s1==s2) 
                {
                    flag=1;
                    cout<<"NO"<<endl;
                    break;
                }
            }
            if(!flag) 
            cout<<"YES"<<endl;
        }
    }
}
int main()
{
    _mzf::mzfmain();
    return 0;
}
View Code

别忘了开O2(正解需要手动离散化)

posted @ 2021-11-19 19:12  云山千叠  阅读(22)  评论(0编辑  收藏  举报