当前位置: 首页 > news >正文

【模板】拓扑排序

B3644 【模板】拓扑排序 / 家谱树 - 洛谷

拓扑排序的步骤:

  • 计算每个点的入度。

  • 入度为 0 就加入队列。

  • 当队列不为空则循环:

    • 取出队首元素并输出。

    • 遍历队首元素的连边,对应节点的入度 −1。

    • 当对应的节点入度为 0 就加入队列。

#include<bits/stdc++.h>
using namespace std;
signed main(){ios::sync_with_stdio(false),cin.tie(0),cout.tie(0);int n;cin>>n;vector<vector<int>>edge(n+1);vector<int>in(n+1);for(int i=1;i<=n;i++){int t;while(1){cin>>t;if(t==0)break;else{edge[i].push_back(t);in[t]++;}}}queue<int>q;for(int i=1;i<=n;i++){if(!in[i])q.push(i);}while(!q.empty()){int f=q.front();cout<<f<<" ";q.pop();for(int i=0;i<edge[f].size();i++){in[edge[f][i]]--;if(in[edge[f][i]]==0)q.push(edge[f][i]);}}return 0;
}

【动画讲解】这绝对是2025年最细最易懂的拓扑排序教程,数据结构和算法_哔哩哔哩_bilibili

http://www.xdnf.cn/news/1276849.html

相关文章:

  • 【嵌入式硬件实例】-555定时器PWM调光电路
  • 通过Certbot自动申请更新HTTPS网站的SSL证书
  • 字节:计算机存储单位
  • Spring Cloud系列—OpenFeign远程调用
  • 【东枫科技】FR3 可扩展测试平台,适用于 6G 研究与卫星通信,高达 1.6 GHz 的带宽
  • 【Html网页模板】炫酷科技风公司首页
  • 正确使用SQL Server中的Hint(10)—Hint简介与Hint分类及语法(1)
  • strace的常用案例
  • GPT-5与中国AI发展(DeepSeek R1视角)
  • FFmpeg实现音视频转码
  • QT的常用控件说明
  • 【从源码角度深度理解 Python 的垃圾回收机制】:第1课引用计数篇
  • C++高频知识点(二十)
  • 电脑使用“碎片整理”程序的作用
  • Vue.js设计于实现 - 概览(二)
  • Vue 事件冒泡处理指南:从入门到精通
  • vue2升级vue3:单文件组件概述 及常用api
  • 基于VuePress2开发文档自部署及嵌入VUE项目
  • 【数据分析】循环移位岭回归分析:光遗传学冻结行为模式研究
  • 2025华数杯比赛还未完全结束!数模论文可以发表期刊会议
  • SAP学习笔记 - 开发57 - RAP开发 Managed App RAP action 之 Accept Travel 和 Reject Travel
  • special topic 8 (2) and topic 9 (1)
  • 一键复制产品信息到剪贴板
  • Kafka消费者相关原理
  • K8s DaemonSet 详解
  • es-drager-blog
  • 安全生产基础知识(一)
  • ThreadLocal的原理是什么,使用场景有哪些?
  • 状态机浅析
  • Linux操作系统从入门到实战(十八)在Linux里面怎么查看进程