mirror of
https://github.com/TheAlgorithms/JavaScript.git
synced 2025-12-19 06:58:15 +08:00
Merge branch 'master' into master
This commit is contained in:
@@ -1,66 +1,71 @@
|
||||
// starting at s
|
||||
function solve (graph, s) {
|
||||
var solutions = {}
|
||||
solutions[s] = []
|
||||
solutions[s].dist = 0
|
||||
function solve(graph, s) {
|
||||
var solutions = {};
|
||||
solutions[s] = [];
|
||||
solutions[s].dist = 0;
|
||||
|
||||
while(true) {
|
||||
var p = null;
|
||||
var neighbor = null;
|
||||
var dist = Infinity;
|
||||
|
||||
|
||||
for(var n in solutions) {
|
||||
if(!solutions[n])
|
||||
continue
|
||||
var ndist = solutions[n].dist;
|
||||
var adj = graph[n];
|
||||
|
||||
for(var a in adj) {
|
||||
|
||||
while (true) {
|
||||
var p = null
|
||||
var neighbor = null
|
||||
var dist = Infinity
|
||||
|
||||
for (var n in solutions) {
|
||||
if (!solutions[n]) { continue }
|
||||
var ndist = solutions[n].dist
|
||||
var adj = graph[n]
|
||||
|
||||
for (var a in adj) {
|
||||
if (solutions[a]) { continue }
|
||||
|
||||
var d = adj[a] + ndist
|
||||
if (d < dist) {
|
||||
p = solutions[n]
|
||||
neighbor = a
|
||||
dist = d
|
||||
if(solutions[a])
|
||||
continue;
|
||||
|
||||
var d = adj[a] + ndist;
|
||||
if(d < dist) {
|
||||
|
||||
p = solutions[n];
|
||||
neighbor = a;
|
||||
dist = d;
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
// no more solutions
|
||||
if (dist === Infinity) {
|
||||
break
|
||||
|
||||
//no more solutions
|
||||
if(dist === Infinity) {
|
||||
break;
|
||||
}
|
||||
|
||||
// extend parent's solution path
|
||||
solutions[neighbor] = p.concat(neighbor)
|
||||
// extend parent's cost
|
||||
solutions[neighbor].dist = dist
|
||||
|
||||
//extend parent's solution path
|
||||
solutions[neighbor] = p.concat(neighbor);
|
||||
//extend parent's cost
|
||||
solutions[neighbor].dist = dist;
|
||||
}
|
||||
|
||||
return solutions
|
||||
|
||||
return solutions;
|
||||
}
|
||||
// create graph
|
||||
var graph = {}
|
||||
//create graph
|
||||
var graph = {};
|
||||
|
||||
var layout = {
|
||||
R: ['2'],
|
||||
2: ['3', '4'],
|
||||
3: ['4', '6', '13'],
|
||||
4: ['5', '8'],
|
||||
5: ['7', '11'],
|
||||
6: ['13', '15'],
|
||||
7: ['10'],
|
||||
8: ['11', '13'],
|
||||
9: ['14'],
|
||||
10: [],
|
||||
11: ['12'],
|
||||
12: [],
|
||||
13: ['14'],
|
||||
14: [],
|
||||
15: []
|
||||
'R': ['2'],
|
||||
'2': ['3','4'],
|
||||
'3': ['4','6','13'],
|
||||
'4': ['5','8'],
|
||||
'5': ['7','11'],
|
||||
'6': ['13','15'],
|
||||
'7': ['10'],
|
||||
'8': ['11','13'],
|
||||
'9': ['14'],
|
||||
'10': [],
|
||||
'11': ['12'],
|
||||
'12': [],
|
||||
'13': ['14'],
|
||||
'14': [],
|
||||
'15': []
|
||||
}
|
||||
|
||||
// convert uni-directional to bi-directional graph
|
||||
//convert uni-directional to bi-directional graph
|
||||
// var graph = {
|
||||
// a: {e:1, b:1, g:3},
|
||||
// b: {a:1, c:1},
|
||||
@@ -72,25 +77,27 @@ var layout = {
|
||||
// h: {f:1}
|
||||
// };
|
||||
|
||||
for (var id in layout) {
|
||||
if (!graph[id]) { graph[id] = {} }
|
||||
layout[id].forEach(function (aid) {
|
||||
graph[id][aid] = 1
|
||||
if (!graph[aid]) { graph[aid] = {} }
|
||||
graph[aid][id] = 1
|
||||
})
|
||||
for(var id in layout) {
|
||||
if(!graph[id])
|
||||
graph[id] = {};
|
||||
layout[id].forEach(function(aid) {
|
||||
graph[id][aid] = 1;
|
||||
if(!graph[aid])
|
||||
graph[aid] = {};
|
||||
graph[aid][id] = 1;
|
||||
});
|
||||
}
|
||||
|
||||
// choose start node
|
||||
var start = '10'
|
||||
// get all solutions
|
||||
var solutions = solve(graph, start)
|
||||
//choose start node
|
||||
var start = '10';
|
||||
//get all solutions
|
||||
var solutions = solve(graph, start);
|
||||
|
||||
console.log("From '" + start + "' to")
|
||||
// display solutions
|
||||
for (var s in solutions) {
|
||||
if (!solutions[s]) continue
|
||||
console.log(' -> ' + s + ': [' + solutions[s].join(', ') + '] (dist:' + solutions[s].dist + ')')
|
||||
console.log("From '"+start+"' to");
|
||||
//display solutions
|
||||
for(var s in solutions) {
|
||||
if(!solutions[s]) continue;
|
||||
console.log(" -> " + s + ": [" + solutions[s].join(", ") + "] (dist:" + solutions[s].dist + ")");
|
||||
}
|
||||
|
||||
// From '10' to
|
||||
|
||||
164
maths/graph.js
164
maths/graph.js
@@ -1,89 +1,95 @@
|
||||
// create a graph class
|
||||
class Graph {
|
||||
// defining vertex array and
|
||||
// adjacent list
|
||||
constructor (noOfVertices) {
|
||||
this.noOfVertices = noOfVertices
|
||||
this.AdjList = new Map()
|
||||
}
|
||||
|
||||
// functions to be implemented
|
||||
|
||||
// addVertex(v)
|
||||
// addEdge(v, w)
|
||||
// printGraph()
|
||||
|
||||
// bfs(v)
|
||||
// dfs(v)
|
||||
// create a graph class
|
||||
class Graph {
|
||||
// defining vertex array and
|
||||
// adjacent list
|
||||
constructor(noOfVertices)
|
||||
{
|
||||
this.noOfVertices = noOfVertices;
|
||||
this.AdjList = new Map();
|
||||
}
|
||||
|
||||
// functions to be implemented
|
||||
|
||||
// addVertex(v)
|
||||
// addEdge(v, w)
|
||||
// printGraph()
|
||||
|
||||
// bfs(v)
|
||||
// dfs(v)
|
||||
}
|
||||
|
||||
// add vertex to the graph
|
||||
addVertex(v)
|
||||
{
|
||||
// initialize the adjacent list with a
|
||||
// null array
|
||||
this.AdjList.set(v, [])
|
||||
// add vertex to the graph
|
||||
addVertex(v)
|
||||
{
|
||||
// initialize the adjacent list with a
|
||||
// null array
|
||||
this.AdjList.set(v, []);
|
||||
}
|
||||
|
||||
// add edge to the graph
|
||||
addEdge(v, w)
|
||||
{
|
||||
// get the list for vertex v and put the
|
||||
// vertex w denoting edge between v and w
|
||||
this.AdjList.get(v).push(w)
|
||||
// add edge to the graph
|
||||
addEdge(v, w)
|
||||
{
|
||||
// get the list for vertex v and put the
|
||||
// vertex w denoting edge between v and w
|
||||
this.AdjList.get(v).push(w);
|
||||
|
||||
// Since graph is undirected,
|
||||
// add an edge from w to v also
|
||||
this.AdjList.get(w).push(v);
|
||||
}
|
||||
|
||||
// Since graph is undirected,
|
||||
// add an edge from w to v also
|
||||
this.AdjList.get(w).push(v)
|
||||
|
||||
// Prints the vertex and adjacency list
|
||||
printGraph()
|
||||
{
|
||||
// get all the vertices
|
||||
var get_keys = this.AdjList.keys();
|
||||
|
||||
// iterate over the vertices
|
||||
for (var i of get_keys)
|
||||
{
|
||||
// great the corresponding adjacency list
|
||||
// for the vertex
|
||||
var get_values = this.AdjList.get(i);
|
||||
var conc = "";
|
||||
|
||||
// iterate over the adjacency list
|
||||
// concatenate the values into a string
|
||||
for (var j of get_values)
|
||||
conc += j + " ";
|
||||
|
||||
// print the vertex and its adjacency list
|
||||
console.log(i + " -> " + conc);
|
||||
}
|
||||
}
|
||||
|
||||
// Prints the vertex and adjacency list
|
||||
printGraph()
|
||||
{
|
||||
// get all the vertices
|
||||
var get_keys = this.AdjList.keys()
|
||||
|
||||
// iterate over the vertices
|
||||
for (var i of get_keys) {
|
||||
// great the corresponding adjacency list
|
||||
// for the vertex
|
||||
var get_values = this.AdjList.get(i)
|
||||
var conc = ''
|
||||
|
||||
// iterate over the adjacency list
|
||||
// concatenate the values into a string
|
||||
for (var j of get_values) { conc += j + ' ' }
|
||||
|
||||
// print the vertex and its adjacency list
|
||||
console.log(i + ' -> ' + conc)
|
||||
}
|
||||
}
|
||||
|
||||
// Example
|
||||
var graph = new Graph(6)
|
||||
var vertices = ['A', 'B', 'C', 'D', 'E', 'F']
|
||||
var graph = new Graph(6);
|
||||
var vertices = [ 'A', 'B', 'C', 'D', 'E', 'F' ];
|
||||
|
||||
// adding vertices
|
||||
for (var i = 0; i < vertices.length; i++) {
|
||||
g.addVertex(vertices[i]);
|
||||
}
|
||||
|
||||
// adding edges
|
||||
g.addEdge('A', 'B');
|
||||
g.addEdge('A', 'D');
|
||||
g.addEdge('A', 'E');
|
||||
g.addEdge('B', 'C');
|
||||
g.addEdge('D', 'E');
|
||||
g.addEdge('E', 'F');
|
||||
g.addEdge('E', 'C');
|
||||
g.addEdge('C', 'F');
|
||||
|
||||
// prints all vertex and
|
||||
// its adjacency list
|
||||
// A -> B D E
|
||||
// B -> A C
|
||||
// C -> B E F
|
||||
// D -> A E
|
||||
// E -> A D F C
|
||||
// F -> E C
|
||||
g.printGraph();
|
||||
|
||||
// adding vertices
|
||||
for (var i = 0; i < vertices.length; i++) {
|
||||
g.addVertex(vertices[i])
|
||||
}
|
||||
|
||||
// adding edges
|
||||
g.addEdge('A', 'B')
|
||||
g.addEdge('A', 'D')
|
||||
g.addEdge('A', 'E')
|
||||
g.addEdge('B', 'C')
|
||||
g.addEdge('D', 'E')
|
||||
g.addEdge('E', 'F')
|
||||
g.addEdge('E', 'C')
|
||||
g.addEdge('C', 'F')
|
||||
|
||||
// prints all vertex and
|
||||
// its adjacency list
|
||||
// A -> B D E
|
||||
// B -> A C
|
||||
// C -> B E F
|
||||
// D -> A E
|
||||
// E -> A D F C
|
||||
// F -> E C
|
||||
g.printGraph()
|
||||
|
||||
Reference in New Issue
Block a user