日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程语言 > java >内容正文

java

Java实现图的深度和广度优先遍历算法

發布時間:2025/3/20 java 23 豆豆
生活随笔 收集整理的這篇文章主要介紹了 Java实现图的深度和广度优先遍历算法 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

概述:

? 最近要學習寫網絡爬蟲,所以把圖的深度和廣度搜索都再溫習一下。


圖結構展示:



實現過程:

首先,我們來看看圖結構在代碼中的實現。有三塊邏輯:

1.圖中的節點:

public class GraphNode {public List<GraphEdge> edgeList = null;private String label = "";public GraphNode(String label) {this.label = label;if (edgeList == null) {edgeList = new ArrayList<GraphEdge>();}}/*** 給當前節點添加一條邊* GraphNode* @param edge* 添加的邊*/public void addEdgeList(GraphEdge edge) {edgeList.add(edge);}public String getLabel() {return label;} } ?

2.圖中的邊:

?

public class GraphEdge {private GraphNode nodeLeft;private GraphNode nodeRight;/*** @param nodeLeft* 邊的左端* @param nodeRight* 邊的右端*/public GraphEdge(GraphNode nodeLeft, GraphNode nodeRight) {this.nodeLeft = nodeLeft;this.nodeRight = nodeRight;}public GraphNode getNodeLeft() {return nodeLeft;}public GraphNode getNodeRight() {return nodeRight;}} ?

3.把節點和邊組合成一個圖結構:

?

public class MyGraph {private List<GraphNode> nodes = null;public void initGraph(int n) {if (nodes == null) {nodes = new ArrayList<GraphNode>();}GraphNode node = null;for (int i = 0; i < n; i++) {node = new GraphNode(String.valueOf(i));nodes.add(node);}}public void initGraph(int n, boolean b) {initGraph(n);GraphEdge edge01 = new GraphEdge(nodes.get(0), nodes.get(1));GraphEdge edge02 = new GraphEdge(nodes.get(0), nodes.get(2));GraphEdge edge13 = new GraphEdge(nodes.get(1), nodes.get(3));GraphEdge edge14 = new GraphEdge(nodes.get(1), nodes.get(4));GraphEdge edge25 = new GraphEdge(nodes.get(2), nodes.get(5));GraphEdge edge26 = new GraphEdge(nodes.get(2), nodes.get(6));GraphEdge edge37 = new GraphEdge(nodes.get(3), nodes.get(7));GraphEdge edge47 = new GraphEdge(nodes.get(4), nodes.get(7));GraphEdge edge56 = new GraphEdge(nodes.get(5), nodes.get(6));nodes.get(0).addEdgeList(edge01);nodes.get(0).addEdgeList(edge02);nodes.get(1).addEdgeList(edge13);nodes.get(1).addEdgeList(edge14);nodes.get(2).addEdgeList(edge25);nodes.get(2).addEdgeList(edge26);nodes.get(3).addEdgeList(edge37);nodes.get(4).addEdgeList(edge47);nodes.get(5).addEdgeList(edge56);}public void initGraph() {initGraph(8, false);}public List<GraphNode> getGraphNodes() {return nodes;} } ?
有了圖的結構,我們就可以進行一些實際的操作了。

深度優先搜索:

?

public class DFSearch {/*** 深度遍歷* DFSearch* @param node* 當前節點* @param visited* 被訪問過的節點列表*/public void searchTraversing(GraphNode node, List<GraphNode> visited) {// 判斷是否遍歷過if (visited.contains(node)) {return;}visited.add(node);System.out.println("節點:" + node.getLabel());for (int i = 0; i < node.edgeList.size(); i++) {searchTraversing(node.edgeList.get(i).getNodeRight(), visited);}} } ?

廣度優先搜索:

?

public class BFSearch {/*** 廣度優先搜索* BFSearch* @param node* 搜索的入口節點*/public void searchTraversing(GraphNode node) {List<GraphNode> visited = new ArrayList<GraphNode>(); // 已經被訪問過的元素Queue<GraphNode> q = new LinkedList<GraphNode>(); // 用隊列存放依次要遍歷的元素q.offer(node);while (!q.isEmpty()) {GraphNode currNode = q.poll();if (!visited.contains(currNode)) {visited.add(currNode);System.out.println("節點:" + currNode.getLabel());for (int i = 0; i < currNode.edgeList.size(); i++) {q.offer(currNode.edgeList.get(i).getNodeRight());}}}} }

?

運行結果:



源碼下載:

http://download.csdn.net/detail/u013761665/8968443

總結

以上是生活随笔為你收集整理的Java实现图的深度和广度优先遍历算法的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。