队列的建立

static Queue r = new LinkedList(); //创建队列
登录后复制

(学习视频分享:java课程)

队列的基本方法

r.offer(); 入队尾

立即学习“Java免费学习笔记(深入)”;

r.poll(); 出队首

r.peek(); 队首的内容

代码实现:

全局变量设置

package Two;

import java.util.LinkedList;
import java.util.Queue;
import java.util.Scanner;

public class BFS {
  static int a[][] = new int [100][100]; //输入迷宫
  static int v[][] = new int [100][100]; //走过的标记为1
  static int startx,starty;    //输入起点位置
  static int p,q;      //输入要到达的坐标位置
  static int dx[] = {0,1,0,-1};  //方向数组
  static int dy[] = {1,0,-1,0}; 
  
  static Queue r = new LinkedList();  //创建队列
  
  
  static class point{     //建立类坐标属性
   int x;
   int y;
   int step;
 
  }
登录后复制

输入迷宫和起始位置,目标位置

public static void main(String[] args) {
  Scanner in = new Scanner(System.in);
  int m = in.nextInt();
  int n = in .nextInt();
  for(int i=1;i

BFS算法开始

1、设置队首

  //BFS
  point start = new point();   //定义一个初始类作为队首
  start.x = startx;
  start.y = starty;
  start.step = 0;
  r.offer(start);
  v[startx][starty]=1;
登录后复制

2、进入循环体

  while(!r.isEmpty()) {        //当队列为空时跳出循环
   
   int x = r.peek().x;      //把队首的属性赋值
   int y = r.peek().y;
   int step = r.peek().step;
   
   
   if(x==p && y==q) {           //到达目的地,退出循环
    System.out.println(step);
    break;
   }
   
   for(int i=0;i

相关推荐:java入门

登录后复制

以上就是利用java算法BFS来求迷宫出口最短路径的详细内容,更多请关注慧达安全导航其它相关文章!

点赞(0)

评论列表 共有 0 条评论

暂无评论
立即
投稿
发表
评论
返回
顶部