经典算法 判断一个图中是否有环

判断一个图中是否有环

问题描述

给一个以0 0结尾的整数对列表,除0 0外的每两个整数表示一条连接了这两个节点的边。假设节点编号不超过100000大于0。你只要判断由这些节点和边构成的图中是否存在环。存在输出YES,不存在输出NO。

输入样例1

in 复制代码
6 8  5 3  5 2  6 4 5 6  0 0

输出样例1

in 复制代码
NO

输入样例2

in 复制代码
8 1  7 3  6 2  8 9  7 5 7 4  7 8  7 6  0 0

输出样例2

in 复制代码
NO

输入样例3

in 复制代码
3 8  6 8  6 4 5 3  5 6  5 2  0 0

输出样例3

in 复制代码
YES

输入样例4

in 复制代码
1 2 3 4 0 0

输出样例4

in 复制代码
NO

输入样例5

空图没有环

cpp 复制代码
0 0

输出样例5

in 复制代码
NO

c++代码

cpp 复制代码
#include<bits/stdc++.h>

using namespace std;

int a, b;
int arr[100001];
bool key = false;

int myfind(int x) {
    int root = x;
    while(root != arr[root]) root = arr[root];
    int i = x, j;
    while(i != root) {
        j = arr[i];
        arr[i] = root;
        i = j;
    }
    return root;
}

void mymerge(int x, int y) {
    x = myfind(x), y = myfind(y);
    if (x != y) arr[y] = arr[x];
}

int main() {
    for (int i = 1; i <= 100000; i++) arr[i] = i;
    while(true) {
        scanf("%d %d", &a, &b);
        if (a == 0 && b == 0) break;
        if (key) continue;
        int x = myfind(a), y = myfind(b);
        if (x == y) key = true;
        else mymerge(a, b);
    }
    if (key) printf("YES");
    else printf("NO");
    return 0;
}//by wqs

算法解析

给每个点一个初始的编号,并初始化所有节点的父亲为本身。每新加入一条边就把边相连的两个集合合并到一起,如果边相连的集合原本就是同一个,说明已经成环。

相关推荐
.30-06Springfield6 分钟前
决策树(Decision tree)算法详解(ID3、C4.5、CART)
人工智能·python·算法·决策树·机器学习
我不是哆啦A梦6 分钟前
破解风电运维“百模大战”困局,机械版ChatGPT诞生?
运维·人工智能·python·算法·chatgpt
xiaolang_8616_wjl11 分钟前
c++文字游戏_闯关打怪
开发语言·数据结构·c++·算法·c++20
WJ.Polar17 分钟前
Python数据容器-list和tuple
开发语言·python
small_wh1te_coder17 分钟前
硬件嵌入式学习路线大总结(一):C语言与linux。内功心法——从入门到精通,彻底打通你的任督二脉!
linux·c语言·汇编·嵌入式硬件·算法·c
FrostedLotus·霜莲31 分钟前
C++主流编辑器特点比较
开发语言·c++·编辑器
超级码.里奥.农33 分钟前
零基础 “入坑” Java--- 七、数组(二)
java·开发语言
KENYCHEN奉孝42 分钟前
Rust征服字节跳动:高并发服务器实战
服务器·开发语言·rust
hqxstudying42 分钟前
Java创建型模式---单例模式
java·数据结构·设计模式·代码规范
挺菜的1 小时前
【算法刷题记录(简单题)002】字符串字符匹配(java代码实现)
java·开发语言·算法