广搜:最短路径

b站视频:
https://www.bilibili.com/video/BV16C4y1s7EF?t=1458

题目:求从起点走到终点的最短路径

输入:
行 列
地图( 1代表可走,2代表障碍物 )
起点坐标x,y
终点坐标x,y

样例:
输入
5 4
1 1 2 1
1 1 1 1
1 1 2 1
1 2 1 1
1 1 1 2
1 1 4 3

输出:
7

import java.awt.List;
import java.util.LinkedList;
import java.util.Scanner;

public class shortRoute {

	static class node{ //定义每个方格
		int x;//横坐标
		int y;//纵坐标
		int step;//从起点到达此方格的步数
		
		public node(int x, int y, int step) {
			this.x = x;
			this.y = y;
			this.step = step;
		}
	}
	
	public static void main(String[] args) {
		Scanner in = new Scanner(System.in);
		int n = in.nextInt();//行
		int m = in.nextInt();//列
		int [][]map = new int[n+2][m+2];//地图  多定义两行方便处理数据
		int [][]visit = new int[n+2][m+2];
		
		//输入数据
		for(int i = 1; i < n+1; i++)
			for(int j = 1; j < m+1; j++)
				map[i][j] = in.nextInt();
			
		int startx = in.nextInt();
		int starty = in.nextInt();
		int endx = in.nextInt();
		int endy = in.nextInt();
		boolean flag = false;//用来判断最后是否有路劲
		
		//方向  
		//右{0,1} 下{0,-1} 左 {-1,0} 上{1,0}
		int []desx ={1,0,-1,0};
		int []desy ={0,-1,0,1};
		
		LinkedList<node> list = new LinkedList<node>();//创建队列
		node start = new node(startx,starty, 0);//初始起点
		list.add(start);//将起点放入队列中
		while(list.size() != 0) {
			//获取队首元素
			int x = list.getFirst().x;
			int y = list.getFirst().y;
			int step = list.getFirst().step;
			 
			//判断是否到达终点
			if ( x==endx && y==endy) {
				System.out.println(step);
				return;
			}
			
			//向4个方向扩展
			for(int i=0; i<4; i++) {
				int tx,ty;
				tx = x + desx[i];
				ty = y + desy[i];
				
				//如果地图可走 并且未拜访过 就将此点加入队列
				if( map[tx][ty] == 1 && visit[tx][ty] == 0) {
					node temp = new node(tx,ty,step+1);
					list.add(temp);
				}
			}
			list.removeFirst();//移除队首
		}
		
		if(!flag) 
			System.out.println("无路径");
	}
}

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值