forked from HaifengDu/ts-ds-tool
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathindex_tes.js
110 lines (105 loc) · 3.47 KB
/
index_tes.js
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
const {Queue , HashMap , dijkstra , PriorityQueue , isconnected
, Graph , GraphVertex , HashSet , MinHeap} = require("./dist/data-structure");
function topoSort(graph){
if (!graph){
return [];
}
const clonedGraph = graph;
const vertices = clonedGraph.getVertexs();
const queue = new PriorityQueue();
vertices.forEach(item => queue.enqueue(item, -item.getInDegree()));
const topoSortedArr = [];
while (!queue.isEmpty()){
const {Value: vertex , Priority: indegree} = queue.dequeue();
if (indegree < 0){
throw new Error("Cyclic dependency " + vertex.Key);
}
topoSortedArr.push(vertex);
const head = vertex.getEdges();
while (head.Size){
const edge = head.getHeadNode().Value;
vertex.deleteEdge(edge);
queue.changePriority(edge.EndVertex, -edge.EndVertex.getInDegree());
}
}
return topoSortedArr;
}
const vertexA = new GraphVertex("A");
const vertexB = new GraphVertex("B");
const vertexC = new GraphVertex("C");
const vertexD = new GraphVertex("D");
const vertexE = new GraphVertex("E");
const vertexF = new GraphVertex("F");
vertexA.addEdge(vertexB);
vertexA.addEdge(vertexC);
vertexA.addEdge(vertexD);
vertexC.addEdge(vertexB);
vertexC.addEdge(vertexE);
vertexD.addEdge(vertexE);
vertexF.addEdge(vertexD);
vertexF.addEdge(vertexE);
const graph = new Graph();
graph
.addVertex(vertexA)
.addVertex(vertexB)
.addVertex(vertexC)
.addVertex(vertexD)
.addVertex(vertexE)
.addVertex(vertexF);
const vertexs = topoSort(graph);
// const edgeSet = new HashSet();
// function getEulerCircuit(
// graph,
// edges,
// startVertex,
// existHashMap,
// prevKey){
// if (!startVertex){
// startVertex = graph.getVertexs()[0];
// }
// if (!edges){
// edges = [];
// }
// if (!startVertex || !graph.findVertex(startVertex.Key)){
// return [];
// }
// existHashMap = existHashMap || new HashMap(graph.getKeys().length);
// const nextNodes = startVertex.getNeighbors();
// existHashMap.put(startVertex.Key , true);
// nextNodes.forEach(item => {
// if(item.Key === prevKey){
// return;
// }
// const edgeKey = JSON.stringify([startVertex.Key,item.Key].sort((a,b) => a>b?1:-1));
// if(!edgeSet.has(edgeKey)){
// if (existHashMap.get(item.Key)){
// edges.push(startVertex.getEdge(item.Key));
// }else{
// existHashMap.put(item.Key,true);
// getEulerCircuit(graph , edges, item , existHashMap , startVertex.Key);
// edges.push(startVertex.getEdge(item.Key));
// }
// edgeSet.add(edgeKey);
// }
// });
// return edges;
// }
// const graph = new Graph(false);
// const vertexs = Array.from({length:10},(item,index) => new GraphVertex(index.toString()));
// vertexs.forEach(item => graph.addVertex(item));
// graph
// .addEdge(vertexs[0],vertexs[8])
// .addEdge(vertexs[0],vertexs[9])
// .addEdge(vertexs[8],vertexs[7])
// .addEdge(vertexs[9],vertexs[2])
// .addEdge(vertexs[9],vertexs[3])
// .addEdge(vertexs[2],vertexs[1])
// .addEdge(vertexs[3],vertexs[1])
// .addEdge(vertexs[9],vertexs[7])
// .addEdge(vertexs[7],vertexs[6])
// .addEdge(vertexs[7],vertexs[5])
// .addEdge(vertexs[6],vertexs[5]);
// const edges = getEulerCircuit(graph);
// console.log(edges);
// const map = edges.map(item => [item.StartVertex.Key,item.EndVertex.Key]);
// console.log(map);