DFS和BFS(无向图)Java实现
Posted
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了DFS和BFS(无向图)Java实现相关的知识,希望对你有一定的参考价值。
package practice; import java.util.Iterator; import java.util.Stack; import edu.princeton.cs.algs4.*; public class TestMain { public static void main(String[] args) { Graph a = new Graph(6); a.addEdge(2, 4); a.addEdge(2, 3); a.addEdge(1, 2); a.addEdge(0, 5); a.addEdge(0, 1); a.addEdge(0, 2); a.addEdge(3, 4); a.addEdge(3, 5); System.out.println(a); DisposeMap df = new DisposeMap(a); /*df.dfs(0); System.out.println(df.hasPathTo(1)); System.out.println(df.hasPathTo(2)); Stack<Integer> aStack = df.pathTo(1); while (!aStack.isEmpty()) { System.out.print(aStack.pop() + "->"); } System.out.println("end");*/ df.bfs(0); for (int i = 0; i < 6; i++) { System.out.println(df.marked(i)); } Stack<Integer> aStack = df.pathTo(4); while (!aStack.isEmpty()) { System.out.print(aStack.pop() + "->"); } System.out.println("end"); } } /* * 图处理dispose */ class DisposeMap { private boolean[] marked; //将已经搜素过的节点储存为true private int count = 0; private Graph G; private int s; //起点 private int[] edgeTo; //edgeTo[w] = v,w为图中的节点,v为它的父节点 public DisposeMap(Graph G) { this.G = G; marked = new boolean[G.V]; edgeTo = new int[G.V]; for (int i = 0; i < marked.length; i++) { marked[i] = false; } } /* * 深度优先搜索,储存以s为起点所能到达的所有点 */ public void dfs(int s) { marked[s] = true; count++; System.out.println("Search" + s); for (Integer b : G.adj(s)) { //搜索一个节点的相邻的第一个没有被标记过的节点 if (marked[b] == false) { //如果没有搜索过这个节点,就搜索它 edgeTo[b] = s; dfs(b); } } } /* * 广度优先搜索 */ public void bfs(int s) { edu.princeton.cs.algs4.Queue<Integer> queue = new Queue<Integer>(); queue.enqueue(s); marked[s] = true; while (!queue.isEmpty()) { Integer temp = queue.dequeue(); for (Integer b : G.adj(temp)) { //搜索一个节点的所有的相邻的节点 if (marked[b] == false) { //如果没有搜索过这个节点,就搜索它 queue.enqueue(b); edgeTo[b] = temp; marked[b] = true; } } } } /* * 查看某点是否被标记 */ public boolean marked(int w) { return marked[w];} /* * 搜索了几个点 */ public int count() { return count;} /* * 是否存在s到v的路径 */ public boolean hasPathTo(int v) { return marked(v); } /* * s到v的路径,有则返回一个Stack,没有则返回null */ public Stack<Integer> pathTo(int v) { Stack<Integer> a = new Stack<Integer>(); for (int i = v; i != s; i = edgeTo[i]) a.push(i); a.push(s); return a; } } /* * 图 */ class Graph { Bag<Integer>[] graph; //这里使用背包的数组,邻借表 int V; int E; public Graph(int V) { this.V = V; graph = (Bag<Integer>[]) new Bag[V]; for (int i = 0; i < graph.length; i++) { graph[i] = (Bag<Integer>) new Bag(); } } /* * 返回顶点数 */ public int V() { return V;} /* * 返回边数 */ public int E() { return E;} /* * 向图中添加一条边 */ public void addEdge(int v, int w) { graph[v].add(w); graph[w].add(v); E++; } /* * 和v相邻的所有顶点 */ public Iterable<Integer> adj(int v) { return graph[v]; } /* * 计算v的度数 */ public static int degree(Graph G, int v) { int degree = 0; for (Integer bag : G.graph[v]) degree++; return degree; } @Override public String toString() { String s = V + " vertices, " + E + " edges\\n"; for (int v = 0; v < V; v++) { s += v + ": "; for (Integer integer : this.adj(v)) { s += integer + " "; } s += "\\n"; } return s; } } /* * 背包 */ class Bag<T> implements Iterable<T> { Node first; private class Node { T value; Node next; } public void add(T value) { Node oldfirst = first; first = new Node(); first.value = value; first.next = oldfirst; } public void delete(T value) { } @Override public Iterator<T> iterator() { return new BagIterator(); } private class BagIterator implements Iterator<T> { Node node = first; @Override public boolean hasNext() { return node != null; } @Override public T next() { T tempt = node.value; node = node.next; return tempt; } } }
代码中的无向图
图的储存-邻接表示意图
以上是关于DFS和BFS(无向图)Java实现的主要内容,如果未能解决你的问题,请参考以下文章