You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
41 lines
856 B
41 lines
856 B
6 years ago
|
function graphTopoSort(numberNodes, edges) {
|
||
|
const nodes = new Map();
|
||
|
const order = [];
|
||
|
const queue = [];
|
||
|
for (let i = 0; i < numberNodes; i++) {
|
||
2 years ago
|
nodes.set(i, { in: 0, out: new Set() });
|
||
6 years ago
|
}
|
||
|
|
||
2 years ago
|
edges.forEach((edge) => {
|
||
6 years ago
|
const [node_id, pre_id] = edge;
|
||
|
nodes.get(node_id).in += 1;
|
||
|
nodes.get(pre_id).out.add(node_id);
|
||
|
});
|
||
|
|
||
|
for (let [node_id, value] of nodes.entries()) {
|
||
|
if (value.in === 0) {
|
||
|
queue.push(node_id);
|
||
|
}
|
||
|
}
|
||
|
|
||
|
while (queue.length) {
|
||
|
const node_id = queue.shift();
|
||
|
for (let outgoing_id of nodes.get(node_id).out) {
|
||
|
nodes.get(outgoing_id).in -= 1;
|
||
|
if (nodes.get(outgoing_id).in === 0) {
|
||
|
queue.push(outgoing_id);
|
||
|
}
|
||
|
}
|
||
|
order.push(node_id);
|
||
|
}
|
||
|
|
||
|
return order.length == numberNodes ? order : [];
|
||
|
}
|
||
|
|
||
2 years ago
|
console.log(
|
||
|
graphTopoSort(3, [
|
||
|
[0, 1],
|
||
|
[0, 2],
|
||
|
]),
|
||
|
);
|