zoukankan      html  css  js  c++  java
  • 洛谷 P1955 [NOI2015] 程序自动分析(并查集,离散化)

    传送门


    解题思路

    很简单的一道并查集,但是我自己却没做出来,关键点没想到,害,还是太菜了……
    直接放重点:

    • 先构建相等关系,然后判断不相等关系成不成立,所以分开操作。
    • 离散化。

    AC代码

    #include<iostream>
    #include<algorithm>
    #include<cmath>
    #include<cstdio>
    #include<cstring>
    #include<cstdlib>
    #include<queue>
    #include<set>
    #include<map>
    #include<vector>
    #include<iomanip>
    #include<ctime>
    #include<stack>
    using namespace std;
    const int maxn=2e6+5;
    int t,n,a[maxn],fa[maxn],cnt,newn;
    struct node{
    	int tp,x,y;
    }q[maxn];
    int find(int x){
    	if(fa[x]==x) return x;
    	return fa[x]=find(fa[x]);
    }
    inline void merge(int x,int y){
    	fa[find(x)]=find(y);
    }
    bool cmp(node a,node b){
    	return a.tp>b.tp;
    }
    int main()
    {
        ios::sync_with_stdio(false);
        cin>>t;
        while(t--){
        	memset(a,0,sizeof(a));
        	cnt=0;
        	cin>>n;
        	for(int i=1;i<=n;i++) cin>>q[i].x>>q[i].y>>q[i].tp,a[++cnt]=q[i].x,a[++cnt]=q[i].y;
        	sort(a+1,a+cnt+1);
        	newn=unique(a+1,a+cnt+1)-a-1;
        	for(int i=0;i<=newn;i++) fa[i]=i;
        	for(int i=1;i<=n;i++){
        		q[i].x=lower_bound(a+1,a+newn+1,q[i].x)-a;
        		q[i].y=lower_bound(a+1,a+newn+1,q[i].y)-a;
    		}
    		sort(q+1,q+n+1,cmp);
    		for(int i=1;i<=n;i++){
    			if(q[i].tp==1) merge(q[i].x,q[i].y);
    			else{
    				if(find(q[i].x)==find(q[i].y)){
    					cout<<"NO"<<endl;
    					break;
    				}
    			}
    			if(i==n) cout<<"YES"<<endl;
    		}
    		
    	}
        return 0;
    }
    

    //NOI2015 D1T1

  • 相关阅读:
    zoj1942Frogger
    阿里云api调用做简单的cmdb
    约瑟夫环
    Bag标签之中的一个行代码实行中文分词实例3
    用lua扩展你的Nginx(整理)
    Single Number III
    TCP/IP ---分层
    TCP/IP --概述
    adb命令学习
    How to set Selenium Python WebDriver default timeout?
  • 原文地址:https://www.cnblogs.com/yinyuqin/p/15085816.html
Copyright © 2011-2022 走看看