【图论】判环问题

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

文章目录

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

例题: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;
相关推荐
阿Y加油吧几秒前
力扣打卡——盛最多水的容器、三数之和
算法·leetcode·排序算法
Barkamin5 分钟前
快速排序非递归实现
java·算法·排序算法
gihigo199810 分钟前
距离角度解耦法的MIMO-OFDM雷达波束形成及优化MATLAB实现
开发语言·算法·matlab
WolfGang00732110 分钟前
代码随想录算法训练营 Day12 | 二叉树 part02
算法·深度优先
2401_8535765016 分钟前
代码自动生成框架
开发语言·c++·算法
逆境不可逃22 分钟前
【从零入门23种设计模式23】行为型之模板模式
java·开发语言·算法·设计模式·职场和发展·模板模式
ZPC821023 分钟前
PPO 在ROS2 中训练与推理
人工智能·算法·机器人
IronMurphy23 分钟前
【算法二十五】105. 从前序与中序遍历序列构造二叉树 236. 二叉树的最近公共祖先
java·数据结构·算法
2401_8535765023 分钟前
C++中的组合模式变体
开发语言·c++·算法
像污秽一样43 分钟前
算法设计与分析-习题8.2
数据结构·算法·排序算法·dfs·化简