java編程無向圖結(jié)構(gòu)的存儲及DFS操作代碼詳解
圖的概念
圖是算法中是樹的拓展,樹是從上向下的數(shù)據(jù)結(jié)構(gòu),結(jié)點都有一個父結(jié)點(根結(jié)點除外),從上向下排列。而圖沒有了父子結(jié)點的概念,圖中的結(jié)點都是平等關系,結(jié)果更加復雜。
無向圖 有向圖
圖G=(V,E),其中V代表頂點Vertex,E代表邊edge,一條邊就是一個定點對(u,v),其中(u,v)∈V。
這兩天遇到一個關于圖的算法,在網(wǎng)上找了很久沒有找到java版的關于數(shù)據(jù)結(jié)構(gòu)中圖的存儲及其相關操作。于是找了一本java版的數(shù)據(jù)結(jié)構(gòu)書看了一下,以下是根據(jù)書上的講解整理的一個關于無向圖的存儲和對圖的深度優(yōu)先遍歷。不過這個遍歷只能遍歷連通圖,要想遍歷非連通圖,還需要修改。在這里分享一下代碼希望對有需要的人有幫助。
package com.homework; /** * 定義棧類 */ class StackX{ private final int size = 20; private int[] st; private int top; //初始化棧 public StackX(){ st = new int[size]; top = -1; } //進棧 public void push(int j){ st[++top] = j; } //出棧 public int pop(){ return st[top--]; } //返回棧頂元素 public int peak(){ return st[top]; } //判斷棧是否為空 public Boolean isEmpty(){ return (top==-1); } } /** * 定義圖中的節(jié)點類 * @author Administrator * */ class Vertex{ public char label; public Boolean wasVisited; public Vertex(char lab){ label = lab; wasVisited = false; } } /** * 定義圖類 * @author Administrator * */ class Graph{ private final int num = 20; private Vertex vertexList[]; //圖中節(jié)點數(shù)組 private int adjMat[][]; //節(jié)點矩陣 private int nVerts; //當前節(jié)點數(shù) private StackX theStack; //定義一個棧 //初始化圖的結(jié)構(gòu) public Graph(){ vertexList = new Vertex[num]; adjMat = new int[num][num]; nVerts = 0; for (int i=0; i<num; i++){ for (int j=0; j<num; j++) adjMat[i][j] = 0; } } //添加節(jié)點 public void addVertex(char lab){ vertexList[nVerts++] = new Vertex(lab); } //添加某兩個節(jié)點之間的邊 public void addEdge(int start,int end){ adjMat[start][end] = 1; adjMat[end][start] = 1; } //輸出某個節(jié)點 public void displayVertex(int v){ System.out.print(vertexList[v].label); } //獲取未被訪問的幾點 public int getAdjUnvisitedVertex(int v){ for (int j=0; j<nVerts; j++){ if(adjMat[v][j]==1 && vertexList[j].wasVisited==false) return j; } return -1; } //深度優(yōu)先遍歷(DFS) public void dfs(){ vertexList[0].wasVisited=true; displayVertex(0); theStack= new StackX(); theStack.push(0); while(!theStack.isEmpty()){ int v = getAdjUnvisitedVertex(theStack.peak()); if(v==-1)//若不存在該節(jié)點 theStack.pop(); else { vertexList[v].wasVisited = true; displayVertex(v); theStack.push(v); } } for (int j=0; j<nVerts; j++) vertexList[j].wasVisited = false; } } public class GraphConnect { public static void main(String[] args){ { Graph theGraph = new Graph(); theGraph.addVertex('A'); theGraph.addVertex('B'); theGraph.addVertex('C'); theGraph.addVertex('D'); theGraph.addVertex('E'); theGraph.addEdge(0, 1); //AB theGraph.addEdge(1, 2); //BC theGraph.addEdge(0, 3); //AD theGraph.addEdge(3, 4); //DE theGraph.addEdge(2, 4); //CE System.out.print("The order visited:"); theGraph.dfs(); System.out.println(); } } }
程序運行的結(jié)果:
The order visited:ABCED
總結(jié)
以上就是本文關于java編程無向圖結(jié)構(gòu)的存儲及DFS操作代碼詳解的全部內(nèi)容,希望對大家有所幫助。感興趣的朋友可以繼續(xù)參閱本站:
Java編程實現(xiàn)基于圖的深度優(yōu)先搜索和廣度優(yōu)先搜索完整代碼
深度優(yōu)先與廣度優(yōu)先Java實現(xiàn)代碼示例
java編程兩種樹形菜單結(jié)構(gòu)的轉(zhuǎn)換代碼
如有不足之處,歡迎留言指出。感謝朋友們對本站的支持!
欄 目:Java編程
下一篇:Java編程實現(xiàn)對十六進制字符串異或運算代碼示例
本文標題:java編程無向圖結(jié)構(gòu)的存儲及DFS操作代碼詳解
本文地址:http://mengdiqiu.com.cn/a1/Javabiancheng/8379.html
您可能感興趣的文章


閱讀排行
本欄相關
- 01-10Java咖啡館(1)——嘆咖啡
- 01-10JVM的垃圾回收機制詳解和調(diào)優(yōu)
- 01-10Java Socket編程(三) 服務器Sockets
- 01-10Java進階:Struts多模塊的技巧
- 01-10J2SE 1.5版本的新特性一覽
- 01-10Java Socket編程(一) Socket傳輸模式
- 01-10Java運行時多態(tài)性的實現(xiàn)
- 01-10Java Socket編程(二) Java面向連接的類
- 01-10Java Socket編程(四) 重復和并發(fā)服務
- 01-10Java經(jīng)驗點滴:處理沒有被捕獲的異常
隨機閱讀
- 01-10delphi制作wav文件的方法
- 08-05dedecms(織夢)副欄目數(shù)量限制代碼修改
- 08-05DEDE織夢data目錄下的sessions文件夾有什
- 01-10SublimeText編譯C開發(fā)環(huán)境設置
- 08-05織夢dedecms什么時候用欄目交叉功能?
- 01-11ajax實現(xiàn)頁面的局部加載
- 04-02jquery與jsp,用jquery
- 01-11Mac OSX 打開原生自帶讀寫NTFS功能(圖文
- 01-10使用C語言求解撲克牌的順子及n個骰子
- 01-10C#中split用法實例總結(jié)