news 2026/4/27 11:45:35

人人都是好朋友【牛客tracker 每日一题】

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
人人都是好朋友【牛客tracker 每日一题】

人人都是好朋友

时间限制:2秒 空间限制:256M

网页链接

牛客tracker

牛客tracker & 每日一题,完成每日打卡,即可获得牛币。获得相应数量的牛币,能在【牛币兑换中心】,换取相应奖品!助力每日有题做,丰盈牛币日益多!

题目描述

牛可乐作为三军统帅,是要时时刻刻关照着下属的。

现在牛可乐想要知道自己的手下之间的友好关系,所以他收集了n nn张纸条,上面写着三个整数a i , b i , c i a_i,b_i,c_iai,bi,ci,表示如果c i c_ici1 11,表示手下a i a_iai和手下b i b_ibi是朋友,反之则是敌人。

牛可乐想要知道这些信息有没有互相矛盾的地方,可是这个问题太难了,只好来问你了

如果AB友好,B又与C友好,那么AC也是友好的。

如果两个人既是友好的又是不友好的则视为相互矛盾的。

牛可乐的手下有 1e9 个。

输入描述:

输入第一行给出一个正整数T TT,表示测试案例的数量。

对于每个测试用例.第一行给出一个正整数n nn,表示有n nn个友好关系

接下来每n nn行给出三个正整数a i , b i , c i a_i,b_i,c_iai,bi,ci,表示手下a i a_iai和手下b i b_ibi之间的友好关系.

输出描述:

每组案例输出一行,若这些关系没有矛盾,输出 "Y E S YESYES”,否则输出 “N O NONO

示例1

输入:

2 3 1 2 1 1 3 1 2 3 1 3 1 2 1 1 3 1 2 3 0

输出:

YES NO

备注:

1 ≤ T ≤ 10 1≤T≤101T10
1 ≤ n ≤ 1 e 6 1≤n≤1e61n1e6

1≤a,b≤1e9

c∈{0,1}

对于每组样例,保证 ∑n≤1010000

建议使用 scanf 读入

解题思路

首先因手下编号达1 e 9 1e91e9,需对所有出现的a i 、 b i a_i、b_iaibi进行离散化(收集所有编号存入数组,排序并去重,将大数映射为小索引);随后初始化并查集,先处理所有c i = 1 c_i=1ci=1的友好关系,通过并查集合并对应编号的映射索引,维护友好关系的传递性;接着遍历所有c i = 0 c_i=0ci=0的敌对关系,查找对应编号的映射索引在并查集中的根节点,若根节点相同则说明两人既是朋友又是敌人,存在矛盾,输出N O NONO;若所有敌对关系的映射索引根节点均不同,输出Y E S YESYES;该方法通过离散化解决大数编号问题,结合并查集高效维护友好关系,时间复杂度适配n nn1 e 6 1e61e6∑ n ≤ 1 e 7 ∑n≤1e7n1e7的规模,精准判断关系是否矛盾。

代码内容

#include<bits/stdc++.h>usingnamespacestd;typedeflonglongll;typedefpair<ll,ll>pii;constll p=1e9+7;constll N=2e6+10;ll fa[N],v[N];structnode{ll x,y,z;}a[N];llget(ll x){if(x==fa[x])returnx;returnfa[x]=get(fa[x]);}voidsolve(){ll n;cin>>n;ll p=0,p1=0;for(ll i=1;i<=n;i++){cin>>a[i].x>>a[i].y>>a[i].z;v[++p]=a[i].x;v[++p]=a[i].y;}sort(v+1,v+1+p);for(ll i=1;i<=p;i++){if(v[i]!=v[p1])v[++p1]=v[i];}for(ll i=1;i<=p1;i++)fa[i]=i;for(ll i=1;i<=n;i++){if(!a[i].z)continue;ll aa=lower_bound(v+1,v+1+p1,a[i].x)-v;ll bb=lower_bound(v+1,v+1+p1,a[i].y)-v;ll x=get(aa),y=get(bb);fa[x]=y;}boolf=1;for(ll i=1;i<=n;i++){if(a[i].z)continue;ll aa=lower_bound(v+1,v+1+p1,a[i].x)-v;ll bb=lower_bound(v+1,v+1+p1,a[i].y)-v;ll x=get(aa),y=get(bb);if(x==y){f=0;break;}}if(f)cout<<"YES\n";elsecout<<"NO\n";}intmain(){ll t;cin>>t;while(t--)solve();return0;}
版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/4/21 2:39:30

工程师 - 奈奎斯特频率

奈奎斯特&#xff08;1889-1976&#xff09;&#xff0c;美国物理学家。1917年获得耶鲁大学工学博士学位。曾在美国AT&T公司与贝尔实验室任职。奈奎斯特为近代信息理论作出了突出贡献。他总结的奈奎斯特采样定理是信息论、特别是通讯与信号处理学科中的一个重要基本结论。奈…

作者头像 李华
网站建设 2026/4/19 10:54:46

通信原理篇---图像信源编码

我们的目标就是&#xff1a;用最小的箱子&#xff08;最少的数据量&#xff09;&#xff0c;装下所有衣服&#xff08;图像信息&#xff09;&#xff0c;并且打开后衣服要基本能用&#xff08;图像可看&#xff09;。 核心思想&#xff1a;扔掉人眼看不出的信息&#xff0c;并用…

作者头像 李华
网站建设 2026/4/18 13:37:30

Elasticsearch 与 PostgreSQL 集成:关系型数据库的搜索增强

Elasticsearch 与 PostgreSQL 集成&#xff1a;让关系型数据库的搜索“飞”起来关键词&#xff1a;Elasticsearch, PostgreSQL, 搜索增强, 数据同步, CDC, 倒排索引, 全文检索 摘要&#xff1a;PostgreSQL是关系型数据库的“瑞士军刀”&#xff0c;擅长事务、复杂查询和数据一致…

作者头像 李华
网站建设 2026/4/24 10:54:44

PyTorch混合精度训练在Miniconda环境中的开启方式

PyTorch混合精度训练在Miniconda环境中的开启方式在深度学习模型日益庞大的今天&#xff0c;训练过程对GPU显存和计算性能的要求几乎达到了临界点。一个典型的Transformer模型在FP32模式下训练时&#xff0c;可能刚加载完参数就已耗尽24GB显存&#xff1b;而同样的模型若启用混…

作者头像 李华
网站建设 2026/4/23 12:45:46

使用Miniconda管理多个PyTorch版本的最佳实践

使用 Miniconda 管理多个 PyTorch 版本的最佳实践 在深度学习项目日益复杂的今天&#xff0c;你是否曾遇到过这样的场景&#xff1a;本地训练好的模型换一台机器就跑不起来&#xff1f;或者某个依赖更新后&#xff0c;原本稳定的代码突然报错“module not found”甚至 GPU 直接…

作者头像 李华