[題解]51nod_1515_明辨是非

Posted superminivan

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了[題解]51nod_1515_明辨是非相关的知识,希望对你有一定的参考价值。

好久沒有話多了,是覺得有點浪費時間,今天考試和一中用的一樣的題,結果反而考得不好,不過Jackpei一句知恥而後勇點醒夢中人偷偷@Jackpei

就是這樣吧

還有我極度懷疑我的鍵帽打油了......我買了假的PBT還是我的手實在是太油了......


 

強制在線,因為不等關係沒有傳遞性,於是用set維護不等關係,并查集維護相等關係,

合併時把set也合併掉,具體就是直接複製合併,複雜度可以接受,雖然並不會算

於是大力瞎搞,我調了半天錯在了合併set搞錯了,it本來就是s[xx]的迭代器,怎麼能和自己互相插入呢......

#include<bits/stdc++.h>
using namespace std;
const int maxn=200010;//開兩倍 
int n,cnt=1;
int fa[maxn];
set<int>s[maxn];
map<int,int>m;
int find(int x)
{
    while(x!=fa[x])x=fa[x]=fa[fa[x]];
    return x;
}
int main()
{
    scanf("%d",&n);
    for(int i=1;i<=n*2;i++)fa[i]=i;
    for(int i=1,x,y,p;i<=n;i++){
        scanf("%d%d%d",&x,&y,&p);
        if(m[x])x=m[x];
        else x=m[x]=++cnt;
        if(m[y])y=m[y];
        else y=m[y]=++cnt;
        int xx=find(x),yy=find(y);
        if(p==1){
            if(s[xx].count(yy))puts("NO");
            else if(xx!=yy){
                puts("YES");
                if(s[xx].size()>s[yy].size())swap(xx,yy);
                fa[xx]=yy;
                for(set<int>::iterator it=s[xx].begin();it!=s[xx].end();it++)
                s[*it].insert(yy),s[yy].insert(*it);
            }
            else puts("YES");
        }
        else{
            if(xx==yy)puts("NO");
            else{
                s[xx].insert(yy);s[yy].insert(xx);
                puts("YES");
            }
        }
    }
}

 

以上是关于[題解]51nod_1515_明辨是非的主要内容,如果未能解决你的问题,请参考以下文章

51nod 1515 明辨是非 [并查集+set]

[51nod1515]明辨是非

51 nod 1515 明辨是非(并查集合并)

51nod-1515 明辨是非——并查集

51nod 1515 明辨是非 并查集+set维护相等与不等关系

51nod 1515 明辨是非 并查集 + set + 启发式合并