Java图的深度优先遍历和广度优先遍历

在这里插入图片描述

根据图的形状建立图的邻接矩阵,并进行初始化

建立代码如下

public class Graph{
	
	//存储图中结点信息
	private List<String> vertexList;

	//存储途中结点与结点之间关系
	private int[][] edges;

	//存储边的数量
	private int numOffEdges;

	//存储结点是否访问过
	private boolean[] booleanList;

	//初始化图
	public Graph(int n){
		vertexList = new ArrayList<String>();
		edges = new int[n][n];
		numOffEdges = 0;
		booleanList = new boolean[n];
	}

	//添加结点信息
	/**
	* node 当前结点
	*/
	public void insertNode(String node){
		vertexList.add(node);
	}
	
	/**
	* 插入结点与结点之间的关系
	* m 代表横坐标
	* n 代表纵坐标
	*/
	//由于是无向图,两边都需添加对应关系
	public void insertRelationship(int m, int n){
		edges[m][n] = 1;
		edges[n][m] = 1;
		numOffEdges++;
	}
	
	//查看结点与结点之间关系
	public void show(){
		for(int i = 0; i < edges.length; i++){
			System.out.println(Arrays.toString(edges[i]));
		}
	}
}

图的深度优先遍历

/**
	* 查看当前结点的下一节点
	* v1 代表横坐标
	*/
	public int getNextNode(int v1, int v2){
		for(int i = v2 +1; i < edges.length; i++){
			if(edges[v1][i] > 0){
				return i;
			}
		}
		return -1;
	}

	//图的深度优先遍历
	/**
	*ver 存储访问过的结点信息
	* i 当前结点的下标
	*/
	public void dfs(boolean[] ver, int i){
		//输出当前结点
		System.out.printf(vertexList.get(i) + "-->");
		//将此节点置为已访问
		ver[i] = true;

		//访问下一个结点
		int nextNode = getNextNode(i , -1);
		while(nextNode != -1){
			//判断该结点是否已经访问过
			if(!ver[nextNode]){
				//没有访问过递归调用输出当前结点
				dfs(ver, nextNode);
			}
			//结点后移
			nextNode = getNextNode(i, nextNode);
		}
	}

图的广度优先遍历

/**
* ver 标记访问过的结点
* i 当前结点
*/
public void bfs(boolean[] ver, int i){
	//创建队列,保存该结点的后续结点
	LinkedList<Integer> list = new LinkedList();
	//判断结点是否访问过,没有访问过进行输出
	System.out.printf(vertexList.get(i) + "-->");
	ver[i] = true;
	list.addLast(i);
    while(!list.isEmpty()){
    	//查到该结点的所有后续结点
		Integer node = list.removeFirst();
        int nextNode = getNextNode(node, -1);
        while(nextNode != -1){
			if(!ver[nextNode]){
				System.out.printf(vertexList.get(nextNode ) + "-->");
				ver[nextNode] = true;
				list.addLast(nextNode);
             }
			nextNode = getNextNode(node, nextNode);
         }
     }
}

主函数的调用

//主函数调用
	public static void main(String[] args) {

        Graph graph = new Graph(5);
        graph.insertNode("A");
        graph.insertNode("B");
        graph.insertNode("C");
        graph.insertNode("D");
        graph.insertNode("E");
        //插入节点与节点之间的关系
        // A-B A-C B-C B-D B-E
        graph.insertRelationship(0, 1, 1);
        graph.insertRelationship(0, 2, 1);
        graph.insertRelationship(1, 2, 1);
        graph.insertRelationship(1, 3, 1);
        graph.insertRelationship(1, 4, 1);
        String[] str = {"A", "B", "C", "D", "E"};
        System.out.println(Arrays.toString(str));
        graph.show();
		//图的深度优先遍历
        graph.dfs();
		//图的广度优先遍历
		graph.bfs();

注意

在该代码中,如果使用深度优先遍历,就不能使用广度优先遍历,二者只能选其一,如果想同时使用,请修改部分代码,以下代码是可以同时进行两种遍历

**

 	//主函数调用
    public static void main(String[] args) {
        //图的结点个数
        int n = 5;
        Graph graph = new Graph(n);
        graph.insertNode("A");
        graph.insertNode("B");
        graph.insertNode("C");
        graph.insertNode("D");
        graph.insertNode("E");
        //插入节点与节点之间的关系
        // A-B A-C B-C B-D B-E
        graph.insertRelationship(0, 1);
        graph.insertRelationship(0, 2);
        graph.insertRelationship(1, 2);
        graph.insertRelationship(1, 3);
        graph.insertRelationship(1, 4);
        String[] str = {"A", "B", "C", "D", "E"};
        System.out.println(Arrays.toString(str));
        graph.show();
        graph.dfs(graph.booleanList, 0);
        graph.booleanList = new boolean[n];
        System.out.println();
        graph.bfs(graph.booleanList, 0);

    }
  • 1
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
深度优先遍历广度优先遍历的两种常见遍历算法。 深度优先遍历(DFS)是一种递归算法,它从中的某个节点开始,首先访问该节点,然后遍历该节点的所有邻接节点,再依次对每个邻接节点进行深度优先遍历。换句话说,DFS会沿着的一条路径一直往下遍历,直到遇到没有未访问过的邻接节点为止,再返回上一级节点继续遍历其他未访问过的节点。DFS的实现一般使用递归或栈来保存待访问节点。 广度优先遍历(BFS)是一种队列的算法,它从中的某个节点开始,首先访问该节点,然后遍历该节点的所有邻接节点,并将这些邻接节点加入队列中。接下来从队列中取出一个节点,再依次遍历该节点的邻接节点,并将未访问过的邻接节点加入队列中,如此往复直到队列为空。BFS的实现一般使用队列来保存待访问节点。 在视频中,可以演示通过邻接矩阵或邻接表的形式来表示,并使用Java代码来实现深度优先遍历广度优先遍历。对于深度优先遍历,可以从中的某个节点开始递归地遍历它的邻接节点,并使用一个标记数组来记录节点是否已经访问过。对于广度优先遍历,可以使用一个队列来按照广度优先的顺序遍历中的节点,并同样使用标记数组来记录节点是否已经访问过。 通过这个视频,观众可以了解到深度优先遍历广度优先遍历的原理和实现方法,并通过代码示例更好地理解其过程。这些算法在的遍历、路径查找等问题中应用广泛,对于理解和解决相关问题具有重要意义。
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值