广度优先搜索——查找系列

广度优先搜索

广度优先搜索解决两类问题

  • 从A出发,有没有到B的路径
  • 从A出发,到B的最短路径是哪条

什么是广度优先搜索?

首先查找离A最近一圈的节点,若这一圈节点都不是B,查找离A最近节点的最近的一圈节点,若都不是B,继续下去直到找到或遍历结束

广度优先搜索代码

为防止因为某个数据第二次出现,而造成的时间浪费甚至死循环,设置一个数组,将出现过的数据加到数组,第二次出现直接弹出。

package Test;

import java.util.ArrayList;
import java.util.HashMap;
import java.util.Iterator;
import java.util.LinkedList;
import java.util.List;
import java.util.Queue;

public class Demo1 {
	
	public static void main(String[] args) {
		LinkedList<String> queue = new LinkedList<String>();
		HashMap<String,String[]> map = new HashMap<String,String[]>();
		init(queue,map);
		find(queue,map,"智多星");
	}
	
	public static void init(LinkedList queue,HashMap map) {
		map.put("宋江",new String[] {"拼命三郎","拼命五郎","拼命七郎","李逵"});
		map.put("拼命三郎",new String[] {"宋江","智多星","入云龙"});
		map.put("拼命五郎",new String[] {"林冲","杨志"});
		queue.add("宋江");
	}
	
	public static void find(LinkedList queue,HashMap map,String goal) {
		List<String> flag = new ArrayList<String>();
		while(!queue.isEmpty()) {
			String name = (String) queue.poll();
			while(flag.contains(name)) {
				System.out.println("朋友重复");
				name = (String) queue.poll();
			}
			flag.add(name);
			if(name.equals(goal)) {
				System.out.println("找到人!");
				break;
			}else {
				if(map.get(name)!=null) {
					String[] names = (String[]) map.get(name);
					for(int i=0;i<names.length;i++) {
						queue.add(names[i]);			
					}
				}
			}
		}
	}
	
}



评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值