【图论】判环问题

(未更新完、做到相关题再更新相关部分

文章目录

无向图判断有无环并输出环上点

例题:H. Mad City

利用变种拓扑排序,先把度为1的点存入队中,每次取出队头,遍历邻接点,再将该条边删除也就是将邻接点度数减一,直至对空,然后所有度数不为0的点都是在环上的点,输出即可

code

cpp 复制代码
for (int i = 0; i < n; i ++ )
{
    int x, y;
    cin >> x >> y;
    add(x, y), add(y, x);

    ind[x] ++, ind[y] ++ ;
}
    
function<void()> topsort = [&]()
{
    queue<int> q;
    for (int i = 1; i <= n; i ++ )
        if (ind[i] == 1) q.push(i);

    while (q.size())
    {
        int u = q.front();
        q.pop();

        for (int i = h[u]; ~i; i = ne[i])
        {
            int v = e[i];
            if (-- ind[v] == 1) q.push(v);
        }
    }
};

topsort();

for (int i = 1; i <= n; i ++ )
	if (ind[i] > 1) ans = true;
相关推荐
ATAOL9 分钟前
数据结构一
数据结构·算法
zyq99101_132 分钟前
Python日期处理实战代码
python·算法·蓝桥杯
罗超驿2 小时前
Java数据结构_链表
java·数据结构·链表
小璐资源网2 小时前
C++中如何正确区分`=`和`==`的使用场景?
java·c++·算法
N1_WEB2 小时前
HDU:杭电 2018 复试真题汇总
算法
AMoon丶2 小时前
C++模版-函数模版,类模版基础
java·linux·c语言·开发语言·jvm·c++·算法
We་ct2 小时前
LeetCode 79. 单词搜索:DFS回溯解法详解
前端·算法·leetcode·typescript·深度优先·个人开发·回溯
眼眸流转3 小时前
LeetCode热题100(四)
算法·leetcode·职场和发展
相信神话20213 小时前
第零章:新手的第一课:正确认知游戏开发
大数据·数据库·算法·2d游戏编程·godot4·2d游戏开发
汀沿河3 小时前
2 模型预训练、微调、强化学习的格式
人工智能·算法·机器学习