左神算法笔记(十一)——图

图的存储方式:邻接表,邻接矩阵

邻接表:
邻接表形式保存图结构

邻接矩阵:
邻接矩阵表示图
具体的方法和定义可以参考图论中的内容。

宽度优先遍历和深度优先遍历

宽度优先遍历:利用队列实现

  1. 从源节点开始依次按照宽度进入队列,然后弹出
  2. 每弹出一个点,就把该节点所有没进过队列的邻接点放入队列
  3. 直到队列变空

BFS:


public static void bfs(Node node){
	if(node == null){
		return;
	}
	Queue<Node> queue = new LinkedList<>();
	HashSet<Node> map = new HashSet<>();
	queue.add(node);
	map.add(node);
	while(!queue.isEmpty()){
		Node cur = queue.poll();
		System.out.println(cur.value);
		for(Node next: cur.nexts){
			if(!map.contains(next)){
				map.add(next);
				queue.add(next);
			}
		}
	}
}

深度优先遍历:利用栈实现

  1. 从源节点开始将节点按照深度放入栈,然后弹出
  2. 每弹出一个点,则将该节点下一个没有进入栈的邻接点放入栈
  3. 直至栈变空
    DFS:
public static void dfs(Node node){
	if(node == null){
		return;
	}
	Stack<Node> stack = new Stack<>();
	HashSet<Node> set = new HashSet<>();
	stack.add(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;
			}
		}
	}
}

拓扑排序算法

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值