图的拓扑序列(BFS)

way:找入度为0的节点删除,减少其他节点的入度,继续找入度为0的节点,直到删除完所有的图节点。(遍历node的neighbors就能得到neighbors的入度信息)

cpp 复制代码
#include<iostream>
#include<vector>
#include<map>
#include<queue>
using namespace std;


class Node {
public:
	int label;
	vector<Node*> neighbors;
	Node(int x)
	{
		label=x;
	}
};


vector<Node*> topSort(vector<Node*> graph)
{
	map<Node*, int>indegreeMap;
	//统计所有节点的入度信息到indegreeMap中
	for(auto node: graph)
	{
		indegreeMap[node]=0;
	}

	for(auto node: graph)
	{
		for(auto next: node->neighbors)
		{
			indegreeMap[next] = indegreeMap[next]+1;
		}
	}

	//将入度为0的节点放入zeroQue中
	queue<Node*> zeroQue;
	for(auto pa: indegreeMap)
	{
		if(pa.second == 0)
		{
			zeroQue.push(pa.first);
		}
	}

	vector<Node*> result;

	//开始删除节点,减少入度
	while(!zeroQue.empty())
	{
		Node *cur = zeroQue.front();
		zeroQue.pop();
		result.push_back(cur);
		for(auto next: cur->neighbors)
		{
			indegreeMap[next] = indegreeMap[next]-1;
			if(indegreeMap[next]==0)
			{
				zeroQue.push(next);
			}
		}
	}
	return result;
}
相关推荐
OJAC1111 分钟前
2026高校毕业生1270万!但这些学生却被名企用高薪“提前预定”!
算法
Controller-Inversion3 分钟前
岛屿问题(dfs典型问题求解)
java·算法·深度优先
小白程序员成长日记4 分钟前
力扣每日一题 2025.11.28
算法·leetcode·职场和发展
Swift社区8 分钟前
LeetCode 435 - 无重叠区间
算法·leetcode·职场和发展
sin_hielo9 分钟前
leetcode 1018
算法·leetcode
大工mike25 分钟前
代码随想录算法训练营第三十一天 | 1049. 最后一块石头的重量 II 494. 目标和 474.一和零
算法
import_random1 小时前
[机器学习]xgboost的2种使用方式
算法
橘颂TA1 小时前
【剑斩OFFER】算法的暴力美学——只出现一次的数字 ||
算法·leetcode·动态规划
想唱rap2 小时前
C++ map和set
linux·运维·服务器·开发语言·c++·算法
小欣加油3 小时前
leetcode 1018 可被5整除的二进制前缀
数据结构·c++·算法·leetcode·职场和发展