Java--算法--图
2021/7/17 20:06:07
本文主要是介绍Java--算法--图,对大家解决编程问题具有一定的参考价值,需要的程序猿们随着小编来一起学习吧!
- 图的基本介绍:
-
图的代码实现:
-
-
package com.model.graph; import java.util.ArrayList; import java.util.Arrays; import java.util.List; /** * @Description:测试类 * @Author: 张紫韩 * @Crete 2021/7/17 15:16 * 演示图的实现,图的快速入门 */ public class GraphDemo01 { public static void main(String[] args) { Graph graph = new Graph(5); graph.insertVertex("A"); graph.insertVertex("B"); graph.insertVertex("C"); graph.insertVertex("D"); graph.insertVertex("E"); graph.addEdges(0, 1, 1); graph.addEdges(0, 2, 1); graph.addEdges(1, 2, 1); graph.addEdges(1, 3, 1); graph.addEdges(1, 4, 1); graph.showGraph(); } } class Graph{ private List<String> vertexList=null;//保存节点的list private int[][] edges=null;//保存边的矩阵 private int numEdges=0;//边的数目 public Graph(int n) { vertexList=new ArrayList<>(n); edges=new int[n][n]; numEdges=0; } // 保存节点的值,第一个节点的名字 public void insertVertex(String vertex){ vertexList.add(vertex); } // 添加边 public void addEdges(int v1,int v2,int weight){ edges[v1][v2]=weight; edges[v2][v1]=weight; numEdges++; } public int getNumOfVertex(){ return vertexList.size(); } public int getNumEdges(){ return numEdges; } // 返回节点的值,名字 public String getVertex(int index){ return vertexList.get(index); } public int getWeight(int v1,int v2){ return edges[v1][v2]; } public void showGraph(){ for (int[] arr:edges){ System.out.println(Arrays.toString(arr)); } } }
-
-
图的遍历-深度优先(DFS):
-
public void dfs(){ for (int i = 0; i < getNumEdges(); i++) { if (!isVisited[i]){ dfs(isVisited, i); } } } // 深度优先算法 private void dfs(boolean[] isVisited, int index) { isVisited[index] = true; System.out.print(vertexList.get(index)+"->"); int neighbor = getFirstNeighbor(index); while (neighbor != -1) { if (!isVisited[neighbor]) { dfs(isVisited, neighbor); } neighbor = getNextNeighbor(index, neighbor); } }
-
图的遍历-广度优先算法(BFS):
-
// 广度优先遍历算法 public void bfs(){ isVisited = new boolean[getNumOfVertex()]; for (int i = 0; i < isVisited.length; i++) { if (!isVisited[i]){ bfs(isVisited,i); } } } // 广度优先遍历算法 public void bfs(boolean[] isVisited, int index){ int u; //队列的头节点的小标 int w;//邻接节点 LinkedList queue=new LinkedList();//记录节点的访问顺序 System.out.print(getVertex(index)+"->"); isVisited[index]=true; queue.addLast(index); while(!queue.isEmpty()){ u= (int) queue.removeFirst(); w=getFirstNeighbor(u); while (w!=-1){ if (!isVisited[w]){ System.out.print(getVertex(w)+"->"); isVisited[w]=true; queue.addLast(w); }else { w=getNextNeighbor(u, w); } } } }
- 深度优先算法和广度优先算法的比较;
-
Graph graph1 = new Graph(8); graph1.insertVertex("1"); graph1.insertVertex("2"); graph1.insertVertex("3"); graph1.insertVertex("4"); graph1.insertVertex("5"); graph1.insertVertex("6"); graph1.insertVertex("7"); graph1.insertVertex("8"); graph1.addEdges(0, 1, 1); graph1.addEdges(0, 2, 1); graph1.addEdges(1, 3, 1); graph1.addEdges(1, 4, 1); graph1.addEdges(3, 7, 1); graph1.addEdges(4, 7, 1); graph1.addEdges(2, 5, 1); graph1.addEdges(2, 6, 1); graph1.addEdges(5, 6, 1); graph1.showGraph(); System.out.println("深度优先算法"); graph1.dfs(); System.out.println(); System.out.println("广度优先算法"); graph1.bfs();
-
这篇关于Java--算法--图的文章就介绍到这儿,希望我们推荐的文章对大家有所帮助,也希望大家多多支持为之网!
- 2025-01-04敏捷管理与看板工具:提升研发、设计、电商团队工作效率的利器
- 2025-01-04智慧养老管理工具如何重塑养老生态?
- 2025-01-04如何打造高绩效销售团队:工具与管理方法的结合
- 2025-01-04解决电商团队协作难题,在线文档工具助力高效沟通
- 2025-01-04春节超市管理工具:解锁高效运营与顾客满意度的双重密码
- 2025-01-046种主流销售预测模型:如何根据场景选用最佳方案
- 2025-01-04外贸服务透明化:增强客户信任与合作的最佳实践
- 2025-01-04重新定义电商团队协作:在线文档工具的战略作用
- 2025-01-04Easysearch Java SDK 2.0.x 使用指南(三)
- 2025-01-04百万架构师第八课:设计模式:设计模式容易混淆的几个对比|JavaGuide