图的深度优先遍历以及广度优先遍历
来源:互联网 发布:评价神户制钢 知乎 编辑:程序博客网 时间:2024/05/21 05:08
import java.util.ArrayList;import java.util.LinkedList;/** * @description 邻接矩阵模型类 * @author beanlam * @time 2015.4.17 */public class AMWGraph { private ArrayList vertexList;//存储点的链表 private int[][] edges;//邻接矩阵,用来存储边 private int numOfEdges;//边的数目 public AMWGraph(int n) { //初始化矩阵,一维数组,和边的数目 edges=new int[n][n]; vertexList=new ArrayList(n); numOfEdges=0; } //得到结点的个数 public int getNumOfVertex() { return vertexList.size(); } //得到边的数目 public int getNumOfEdges() { return numOfEdges; } //返回结点i的数据 public Object getValueByIndex(int i) { return vertexList.get(i); } //返回v1,v2的权值 public int getWeight(int v1,int v2) { return edges[v1][v2]; } //插入结点 public void insertVertex(Object vertex) { vertexList.add(vertexList.size(),vertex); } //插入结点 public void insertEdge(int v1,int v2,int weight) { edges[v1][v2]=weight; numOfEdges++; } //删除结点 public void deleteEdge(int v1,int v2) { edges[v1][v2]=0; numOfEdges--; } //得到第一个邻接结点的下标 public int getFirstNeighbor(int index) { for(int j=0;j<vertexList.size();j++) { if (edges[index][j]>0) { return j; } } return -1; } //根据前一个邻接结点的下标来取得下一个邻接结点 public int getNextNeighbor(int v1,int v2) { for (int j=v2+1;j<vertexList.size();j++) { if (edges[v1][j]>0) { return j; } } return -1; } //私有函数,深度优先遍历 private void depthFirstSearch(boolean[] isVisited,int i) { //首先访问该结点,在控制台打印出来 System.out.print(getValueByIndex(i)+" "); //置该结点为已访问 isVisited[i]=true; int w=getFirstNeighbor(i);// while (w!=-1) { if (!isVisited[w]) { depthFirstSearch(isVisited,w); } w=getNextNeighbor(i, w); } } //对外公开函数,深度优先遍历,与其同名私有函数属于方法重载 public void depthFirstSearch() { for(int i=0;i<getNumOfVertex();i++) { //因为对于非连通图来说,并不是通过一个结点就一定可以遍历所有结点的。 if (!isVisited[i]) { depthFirstSearch(isVisited,i); } } } //私有函数,广度优先遍历 private void broadFirstSearch(boolean[] isVisited,int i) { int u,w; LinkedList queue=new LinkedList(); //访问结点i System.out.print(getValueByIndex(i)+" "); isVisited[i]=true; //结点入队列 queue.addlast(i); while (!queue.isEmpty()) { u=((Integer)queue.removeFirst()).intValue(); w=getFirstNeighbor(u); while(w!=-1) { if(!isVisited[w]) { //访问该结点 System.out.print(getValueByIndex(w)+" "); //标记已被访问 isVisited[w]=true; //入队列 queue.addLast(w); } //寻找下一个邻接结点 w=getNextNeighbor(u, w); } } } //对外公开函数,广度优先遍历 public void broadFirstSearch() { for(int i=0;i<getNumOfVertex();i++) { if(!isVisited[i]) { broadFirstSearch(isVisited, i); } } }}
阅读全文
0 0
- 图的深度优先遍历以及广度优先遍历
- 图的存储以及深度优先以及广度优先遍历
- 图的遍历-(深度优先&广度优先)
- 图的遍历:深度优先、广度优先
- 二叉树的深度优先遍历以及广度优先遍历
- 邻接表的深度优先遍历以及广度优先遍历
- 图:图的遍历(深度优先遍历、广度优先遍历)
- 图的遍历:深度优先遍历和广度优先遍历
- 图:存储结构、深度优先遍历以及广度优先遍历
- 图的深度优先遍历和广度优先遍历算法
- 图的深度优先遍历和广度优先遍历实现
- 图的深度优先遍历和广度优先遍历
- 图的深度优先遍历和广度优先遍历
- 图的深度优先遍历与广度优先遍历
- 图的深度优先遍历和广度优先遍历
- 图的深度优先遍历和广度优先遍历
- 图的广度优先遍历和深度优先遍历
- 图的创建 深度优先遍历 广度优先遍历
- easyui-datagrid关于展示的字段需要进行数据类型转换的问题(自己记录备忘)
- git日常命令
- Struts2,action中用spring注入,启动服务时注入成功,action运行时对象又变成null了
- Python机器学习Numpy, Scipy, Pandas, Scikit-learn, Matplotlib, Keras, NN速查手册
- 糟糕的每日站会
- 图的深度优先遍历以及广度优先遍历
- iOS下KVO使用过程中的陷阱
- PHP获取上周、本周、上月、本月、本季度、上季度时间方法大全
- eclispe中的maven项目使用spring报 org.springframework.web.filter.CharacterEncodingFilter 找不到
- 2017年第0届浙江工业大学之江学院程序设计竞赛决赛 G.qwb去面试【贪心】
- 面试了那么些软件测试人发现的问题
- linux下Telnet问题总结
- Android Studio关联Git及使用
- Android动画详解总览