PTA 2026天体选拔赛(多校联赛)L2-1 仪式网络(C++ 含代码解释)

Problem Description:

在诡秘之主的世界中,灵界节点之间原本通过稳定的"灵性通道"构成一个完整的仪式网络。

最初共有 n 个灵性节点,这些节点之间原本构成一棵稳定的灵性树状结构。

但后来由于某位非凡者误触禁忌,在其中额外打开了一条新的灵性通道。

于是,整个结构变成:n 个节点,n 条通道,出现了一个"灵性回路"。

为了恢复仪式稳定性,你需要找出一条可以关闭的灵性通道,使得剩余结构重新变为一棵合法的灵性树

Input:

第一行输入一个正整数 n(3≤n≤105),表示灵性节点数量。

接下来 n 行,每行包含两个整数 a,b(1≤a,b≤),表示编号为 a 与 b 的两个节点之间存在一条灵性通道。

Output:

输出一个整数 i,表示应当删除的边的编号(边的编号按输入顺序从 1 开始编号)。

若存在多个可删除的边,输出编号最大的那个。

输入样例:

cpp 复制代码
5
1 2
2 3
3 4
1 4
1 5

输出样例:

cpp 复制代码
4

思路:

这道题第一眼会认为是一道图论题,但因为数据量给的比较大,如果暴力写会超时。这道题的关键在于判断回路构成条件(点==边),在这里我们可以使用并查集进行解题。如果在连接起某两个点之后构成了回路,说明这两个点之前必然都出现过。因此,对于这种集合与集合之间关系的问题,可以使用并查集来解决。

AC代码:

cpp 复制代码
#include <bits/stdc++.h>
using namespace std;
const int N = 1e5+10;
int fa[N],x[N],y[N];
int find(int x)//并查集板子
{
    return x==fa[x]?x:fa[x]=find(fa[x]);
}
void Union(int x,int y)
{
    int rootx=find(x);
    int rooty=find(y);
    if(rootx!=rooty)
    {
        if(rootx<rooty) fa[rootx]=rooty;
        else fa[rooty]=rootx;
    }
}
int main()
{
    for(int i=0;i<=N;i++) fa[i]=i;//并查集一定要进行初始化
    int n;
    cin>>n;
    for(int i=1;i<=n;i++)
    {
        cin>>x[i]>>y[i];
        if(find(x[i])!=find(y[i])) Union(x[i],y[i]);//如果两个点不在一个集合内,合并
        else cout<<i;//如果两个点之前都出现过,加上这条边以后便会形成回路
    }
    return 0;
}

评测详情:

相关推荐
clint4562 天前
C++进阶(1)——前景提要
c++
夜悊3 天前
C++代码示例:进制数简单生成工具
c++
郝学胜_神的一滴3 天前
CMake 021: IF 条件判据详诠
c++·cmake
_wyt0013 天前
洛谷 B3930 [GESP202312 五级] 烹饪问题 题解
c++·gesp
LDR0063 天前
Type-C 快充全面升级!LDR6601 赋能个人护理便携电机,重塑剃须刀 / 理发器新体验
c语言·开发语言
雪碧聊技术3 天前
Tree.js是什么?一文讲透
开发语言·javascript·ecmascript
码云数智-园园3 天前
C++20 Modules 模块详解
java·开发语言·spring
swordbob3 天前
NIO的channel中什么是 fd(File Descriptor,文件描述符)
java·开发语言·nio
源分享3 天前
Java线程同步的多种实现方法(非常详细)
java·开发语言·jvm
Luminous.3 天前
C语言--day30
c语言·开发语言