标签:P1955 return int scanf 查集 tot NOI2015 xx find
程序自动分析
解题思路
先排序
把所有e=1的操作放在前面
然后再进行e=0的操作
在进行e=1的操作的时候
我们只要把它约束的两个变量放在同一个集合里面即可
在e=0,即存在一条不相等的约束条件,
于它约束的两个变量
如果在一个集合里面
那就不可能满足
如不相等的约束条件都满足
那就YES
数据太大,建议用离散化
离散化
AC代码
#include<algorithm>
#include<cstdio>
using namespace std;
int tot,f[1000005],b[100005*3];
struct node
{
int x,y,z;
}a[1000005];
bool cmp(node x,node y)
{
return x.z>y.z;
}
int find(int x)
{
if(f[x]==x)return x;
return f[x]=find(f[x]);
}
int main()
{
int n,t;
scanf("%d",&t);
while(t--)
{
int ok=1;
tot=0;
scanf("%d",&n);
for(int i=1;i<=n;i++)
{
scanf("%d%d%d",&a[i].x,&a[i].y,&a[i].z);
b[++tot]=a[i].x;
b[++tot]=a[i].y;
}
sort(b,b+tot);
int m=unique(b,b+tot)-b;//去重
for(int i=1;i<=n;i++)
{
a[i].x=lower_bound(b,b+m,a[i].x)-b;
a[i].y=lower_bound(b,b+m,a[i].y)-b;
}
for(int i=1;i<=m;i++)f[i]=i;//初值
sort(a+1,a+n+1,cmp);//排序
for(int i=1;i<=n;i++)
{
int xx=find(a[i].x),yy=find(a[i].y);
if(a[i].z)f[xx]=yy;
else if(xx==yy)
{
printf("NO\n");
ok=0;
break;
}
}
if(ok)printf("YES\n");
}
return 0;
}
谢谢
标签:P1955,return,int,scanf,查集,tot,NOI2015,xx,find 来源: https://blog.csdn.net/weixin_45524309/article/details/115772007
本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享; 2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关; 3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关; 4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除; 5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。