基本並查集+離散化(重點)洛谷P1955
阿新 • • 發佈:2019-03-03
blog cst max 元素 eps 重復 int color typedef
題目鏈接:https://www.luogu.org/problemnew/show/P1955
推薦參考博客:https://www.cnblogs.com/cytus/p/8933597.html
這題可以用並查集+離散化做,其中離散化我覺得才是最重要的,如果用map容器來離散化我一直TLE,後來了解了一下怎麽離散化,對於有重復元素的序列,我們離散化的時候可以用unique函數,但是用之前必須排序,然後二分來得到離散化之後的編號。
這題思路就是先處理相等的情況,也就是1的情況,然後在處理不相等的情況。
代碼:
#include<iostream> #include<cstring> #include<algorithm> #include<queue> #include<map> #include<stack> #include<cmath> #include<vector> #include<set> #include<cstdio> #include<string> #include<deque> using namespace std; typedef long long LL; #define eps 1e-8 #define INF 0x3f3f3f3f #definemaxn 100005 int pre[2*maxn],b[2*maxn]; int n,m,k,t,cnt; struct node{ int x,y,op; }a[maxn]; void init(int n){ for(int i=0;i<=2*n+1;i++) pre[i]=i; cnt=0; } int find(int x){ return pre[x]=pre[x]==x?x:find(pre[x]); } int main() { scanf("%d",&t); while(t--){ scanf("%d",&n); init(n); int x,y,op,flag=0; for(int i=1;i<=n;i++){ scanf("%d%d%d",&a[i].x,&a[i].y,&a[i].op); b[++cnt]=a[i].x;//把所有元素復制到b數組 b[++cnt]=a[i].y; } sort(b+1,b+cnt+1);//先對b數組排序 int size=unique(b+1,b+cnt+1)-b;//用unique得到不重復的元素個數 for(int i=1;i<=n;i++){ a[i].x=lower_bound(b+1,b+size+1,a[i].x)-b;//二分查找,得到離散化之後的編號 a[i].y=lower_bound(b+1,b+size+1,a[i].y)-b; } for(int i=1;i<=n;i++){ x=a[i].x,y=a[i].y,op=a[i].op; if(a[i].op==1){ int x_fa=find(x); int y_fa=find(y); if(x_fa!=y_fa) pre[x_fa]=y_fa; } } for(int i=1;i<=n;i++){ if(a[i].op==0){ x=a[i].x,y=a[i].y,op=a[i].op; int x_fa=find(x); int y_fa=find(y); if(x_fa==y_fa){ flag=1; break; } } } if(flag) printf("NO\n"); else printf("YES\n"); } return 0; }
基本並查集+離散化(重點)洛谷P1955