栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 软件开发 > 后端开发 > Java

图的深度优先遍历

Java 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

图的深度优先遍历

利用栈实现。

从源点开始按照深度把节点放入栈中,然后再弹出。

每弹出一个节点,把该节点一个没有进入栈中的节点放入栈中,并把该节点也放入栈中,方便回溯。

直到栈变空。

public static void dfs(Node node) {
		if(node == null) {
			return;
		}
		Stack stack =  new Stack();
		HashSet set = new HashSet();
		
		stack.push(node);
		set.add(node);
		System.out.println(node.value);
		while(!stack.isEmpty()) {
			Node cur = stack.pop();
			for(Node next:cur.nexts) {
				if(!set.contains(next)) {
					stack.push(cur);//把当前元素也压入栈中是为了可以回溯。
					//如果不压入栈中,等一条路走不通的时候,无法往后回溯去其他路。
					stack.push(next);
					set.add(next);
					System.out.println(next.value);
					break;
				}
				
				
			}
			
			
			
			
		}
		
		
	}

转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/769920.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号