300字范文,内容丰富有趣,生活中的好帮手!
300字范文 > 迷宫最近距离

迷宫最近距离

时间:2024-02-11 03:57:42

相关推荐

迷宫最近距离

广搜代码如下:

import java.util.LinkedList;import java.util.Queue;import java.util.Scanner;public class Main{public static final int[][] maze = new int[][] {{0,1,0,0,0,1,1,1,0,1,0,1},{0,0,0,1,0,0,0,0,1,0,0,1},{0,1,0,1,0,1,1,1,0,1,0,0},{0,1,0,0,0,0,0,1,0,0,1,1},{0,0,0,0,1,0,0,0,0,0,0,0},{0,0,1,0,0,0,1,0,0,0,1,0},{0,0,1,0,0,0,0,0,1,0,0,0},{1,0,0,1,0,1,0,0,0,1,0,1},{0,0,1,0,1,0,1,0,1,0,0,0},{0,0,0,0,0,1,0,0,0,1,1,0},{0,0,0,0,0,1,0,0,0,0,0,0},{0,1,0,1,0,0,0,1,0,1,0,0}};public static final int N = 12;public static int sx, sy, gx, gy;public static int[] dx = new int[] {1, 0, -1, 0};public static int[] dy = new int[] {0, 1, 0, -1};public static int[][] d = new int[150][150];//记录到该点最小步数public static final int INF = 10000000;public static class Point{public int x, y;public Point(int x, int y){this.x = x;this.y = y;}}public static void main(String[] args){Scanner cin = new Scanner(System.in);sx = cin.nextInt();sy = cin.nextInt();gx = cin.nextInt();gy = cin.nextInt();cin.close();System.out.println(bfs());}public static int bfs(){Queue<Point> queue = new LinkedList<Point>();for (int i = 0; i < N; ++i){for (int j = 0; j < N; ++j){d[i][j] = INF;//初始化}}queue.add(new Point(sx, sy));d[sx][sy] = 0;//到起点的步数为0while (!queue.isEmpty()){Point p = queue.poll();if (p.x == gx && p.y == gy)break;for (int i = 0; i < 4; ++i){int nx = p.x + dx[i];int ny = p.y + dy[i];if (nx >= 0 && nx < N && ny >= 0 && ny < N && maze[nx][ny] != 1 && d[nx][ny] == INF){queue.add(new Point(nx, ny));d[nx][ny] = d[p.x][p.y] + 1;}}}//到达不了的情况if (d[gx][gy] == INF){return 10000;}return d[gx][gy];}}

========================================Talk is cheap, show me the code=======================================

本内容不代表本网观点和政治立场,如有侵犯你的权益请联系我们处理。
网友评论
网友评论仅供其表达个人看法,并不表明网站立场。