mirror of
https://github.moeyy.xyz/https://github.com/TheAlgorithms/C.git
synced 2023-10-11 15:56:24 +08:00
125 lines
3.2 KiB
C
125 lines
3.2 KiB
C
#include <stdbool.h>
|
|
#include <stdio.h>
|
|
#include "Graph.h"
|
|
#include "queue.h"
|
|
|
|
#define MAX_NODES 1000
|
|
|
|
int visited[MAX_NODES]; // array to store visiting order
|
|
// indexed by vertex 0..nV-1
|
|
|
|
bool findPathBFS(Graph g, int nV, Vertex src, Vertex dest)
|
|
{
|
|
Vertex v;
|
|
for (v = 0; v < nV; v++) visited[v] = -1;
|
|
|
|
visited[src] = src;
|
|
queue Q = newQueue();
|
|
QueueEnqueue(Q, src);
|
|
while (!QueueIsEmpty(Q))
|
|
{
|
|
v = QueueDequeue(Q);
|
|
Vertex w;
|
|
for (w = 0; w < nV; w++)
|
|
if (adjacent(g, v, w) && visited[w] == -1)
|
|
{
|
|
visited[w] = v;
|
|
if (w == dest)
|
|
return true;
|
|
else
|
|
QueueEnqueue(Q, w);
|
|
}
|
|
}
|
|
return false;
|
|
}
|
|
|
|
int main(void)
|
|
{
|
|
int V = 10;
|
|
Graph g = newGraph(V);
|
|
|
|
Edge e;
|
|
e.v = 0;
|
|
e.w = 1;
|
|
insertEdge(g, e);
|
|
e.v = 0;
|
|
e.w = 2;
|
|
insertEdge(g, e);
|
|
e.v = 0;
|
|
e.w = 5;
|
|
insertEdge(g, e);
|
|
e.v = 1;
|
|
e.w = 5;
|
|
insertEdge(g, e);
|
|
e.v = 2;
|
|
e.w = 3;
|
|
insertEdge(g, e);
|
|
e.v = 3;
|
|
e.w = 4;
|
|
insertEdge(g, e);
|
|
e.v = 3;
|
|
e.w = 5;
|
|
insertEdge(g, e);
|
|
e.v = 3;
|
|
e.w = 8;
|
|
insertEdge(g, e);
|
|
e.v = 4;
|
|
e.w = 5;
|
|
insertEdge(g, e);
|
|
e.v = 4;
|
|
e.w = 7;
|
|
insertEdge(g, e);
|
|
e.v = 4;
|
|
e.w = 8;
|
|
insertEdge(g, e);
|
|
e.v = 5;
|
|
e.w = 6;
|
|
insertEdge(g, e);
|
|
e.v = 7;
|
|
e.w = 8;
|
|
insertEdge(g, e);
|
|
e.v = 7;
|
|
e.w = 9;
|
|
insertEdge(g, e);
|
|
e.v = 8;
|
|
e.w = 9;
|
|
insertEdge(g, e);
|
|
|
|
int src = 0, dest = 6;
|
|
if (findPathBFS(g, V, src, dest))
|
|
{
|
|
Vertex v = dest;
|
|
while (v != src)
|
|
{
|
|
printf("%d - ", v);
|
|
v = visited[v];
|
|
}
|
|
printf("%d\n", src);
|
|
}
|
|
return 0;
|
|
}
|
|
|
|
// By
|
|
// .----------------. .----------------. .----------------.
|
|
// .-----------------. .----------------. .----------------.
|
|
// | .--------------. || .--------------. || .--------------. ||
|
|
// .--------------. | | .--------------. || .--------------. | | | _________ |
|
|
// || | _____ _____ | || | __ | || | ____ _____ | | | | ____ ____
|
|
// | || | ____ | | | | | _ _ | | || ||_ _||_ _|| || | / \
|
|
// | || ||_ \|_ _| | | | | |_ || _| | || | .' `. | | | | |_/ | |
|
|
// \_| | || | | | | | | || | / /\ \ | || | | \ | | | | | | |
|
|
// |__| | | || | / .--. \ | | | | | | | || | | ' ' | | || |
|
|
// / ____ \ | || | | |\ \| | | | | | | __ | | || | | | | | | |
|
|
// | | _| |_ | || | \ `--' / | || | _/ / \ \_ | || | _| |_\ |_
|
|
// | | | | _| | | |_ | || | \ `--' / | | | | |_____| | || | `.__.'
|
|
// | || ||____| |____|| || ||_____|\____| | | | | |____||____| | || | `.____.'
|
|
// | | | | | || | | || | | || | | | | |
|
|
// | || | | | | '--------------' || '--------------' ||
|
|
// '--------------' || '--------------' | | '--------------' || '--------------'
|
|
// |
|
|
// '----------------' '----------------' '----------------'
|
|
// '----------------' '----------------' '----------------'
|
|
|
|
// Email : z5261243@unsw.edu.au
|
|
// hhoanhtuann@gmail.com
|