广度优先搜索
广度优先搜索解决两类问题
- 从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]);
}
}
}
}
}
}