首页 > 编程语言 >每日OJ题_牛客_AB20走迷宫_BFS_C++_Java

每日OJ题_牛客_AB20走迷宫_BFS_C++_Java

时间:2024-10-29 23:20:07浏览次数:3  
标签:Java OJ AB20 int y1 ys x1 public xt

目录

牛客_AB20走迷宫_BFS

题目解析

C++代码

Java代码


牛客_AB20走迷宫_BFS

走迷宫_牛客题霸_牛客网 (nowcoder.com)

描述:

        给定一个n×m的网格,在网格中每次在不超过边界的情况下可以选择向上、向下、向左、向右移动一格。网格中的一些格子上放置有障碍物,放有障碍物的格子不能到达。求从(xs,ys)(xs​,ys​)到(xt,yt)(xt​,yt​)最少的移动次数。若不能到达,输出−1。

输入描述:

        第一行输入两个整数n,mn,m (1≤n,m≤10001≤n,m≤1000),表示网格大小。
        第二行输入四个整数xs,ys,xt,ytxs​,ys​,xt​,yt​ (1≤xs,xt≤n1≤xs​,xt​≤n, 1≤ys,yt≤m1≤ys​,yt​≤m),表示起点和终点的坐标。
        接下来的n行,每行输入一个长度为m的字符串。其中,第i行第j个字符表示第i行第j列的格子上的障碍物情况,若字符为'*',则格子上有障碍物,若字符为'.',则格子上没有障碍物。保证起点不存在障碍物。

输出描述:

输出一行一个整数,表示从(xs,ys)(xs​,ys​)到(xt,yt)(xt​,yt​)最少的移动次数。


题目解析

  • 广度优先遍历,是一种层次遍历。它从起点开始,从上往下从左到右进行遍历。这种层次遍历,可以确保起点到终点的路径是 最短的最坏情况下,也就是将所有的节点遍历一次,才能找到终点。但是呢,广度优先遍历不太适用于找路径的条数,归根结底,还是因为一般的层次遍历,节点只知道自己当前所在的层次并不知道自己是由哪一个节点过来的。

  • 判断是两个坐标是否相同,相同返回零。
  • bfs广度优先搜索,用while循环将新创建的steps[][]进行层次遍历迭代。
  • 判断目标坐标内容是否发生改变,如果没有,那么无法bsf到该目标坐标,返回-1。

C++代码

#include <iostream>
#include <queue>
#include <utility>
#include <vector>
using namespace std;

int n = 0, m = 0;
int x1, y1, x2, y2;
int dx[4] = {0, 0, -1, 1};
int dy[4] = {1, -1, 0, 0};
bool vis[1007][1007];

void bfs(vector<vector<char>>& vv, vector<vector<int>>& cnt)
{
    queue<pair<int, int>> q;
    q.push({x1, y1});
    vis[x1][y1] = true;
    while(q.size())
    {
        auto[a, b] = q.front();
        q.pop();
        if(a == x2 && b == y2)
            return;
        for(int i = 0; i < 4; ++i)
        {
            int x = dx[i] + a, y = dy[i] + b;
            // cout << x << " " << y << endl;
            if(x <= n && x > 0 && y <= m && y > 0 
                && !vis[x][y] && vv[x][y] == '.')
            {
                q.push({x, y});
                vis[x][y] = true;
                cnt[x][y] = cnt[a][b] + 1;
                // cout << x << " " << y << endl;
                // cout << cnt << endl;
            }
        }
    }
}

signed main()
{
    cin >> n >> m;
    cin >> x1 >> y1 >> x2 >> y2;
    vector<vector<char>> vv(n + 1, vector<char>(m + 1));
    vector<vector<int>> cnt(n + 1, vector<int>(m + 1));
    for(int i = 1; i <= n; ++i)
    {
        for(int j = 1; j <= m; ++j)
        {
            cin >> vv[i][j];
        }
    }
    if(vv[x1][y1] == '*' || vv[x2][y2] == '*')
    {
        cout << -1 << endl;
        return 0;
    }
    bfs(vv, cnt);
    // for(int i = 1; i <= n; ++i)
    // {
    //     for(int j = 1; j <= m; ++j)
    //     {
    //         cout << cnt[i][j] << " ";
    //     }
    //     cout << endl;
    // }
    if(cnt[x2][y2] == 0)
        cout << -1 << endl;
    else
        cout << cnt[x2][y2] << endl;
    return 0;
}

Java代码

import java.util.*;
// 注意类名必须为 Main, 不要有任何 package xxx 信息
public class Main
{
    public static int N = 1010;
    public static int[] dx = {0, 0, 1, -1};
    public static int[] dy = {-1, 1, 0, 0};
    public static int n, m, x1, y1, x2, y2;
    public static char[][] arr = new char[N][N];
    public static int[][] dist = new int[N][N]; // 标记当前位置有没有搜索过,以及⾛到该位置时候的最短步数
	public static int bfs()
    {
        if(arr[x2][y2] == '*')
            return -1;
        for(int i = 1; i <= n; i++)
        {
            for(int j = 1; j <= m; j++)
            {
                dist[i][j] = -1; // 表明刚开始每个位置都没有搜索过
            }
        }

        Queue<int[]> q = new LinkedList<>();
        q.add(new int[]{x1, y1});
        dist[x1][y1] = 0;
        while(!q.isEmpty())
        {
            int[] t = q.poll();
            int a = t[0], b = t[1];
            for(int i = 0; i < 4; i++)
            {
                int x = a + dx[i], y = b + dy[i];
                if(x >= 1 && x <= n && y >= 1 && y <= m && arr[x][y] == '.' &&  dist[x][y] == -1)
                {
                    q.add(new int[]{x, y});
                    dist[x][y] = dist[a][b] + 1;
                    if(x == x2 && y == y2)
                    {
                        return dist[x][y];
                    }
                }
            }
        }
        return -1;
    }
    public static void main(String[] args) 
    {
        Scanner in = new Scanner(System.in);
        n = in.nextInt(); m = in.nextInt();
        x1 = in.nextInt(); y1 = in.nextInt();
        x2 = in.nextInt(); y2 = in.nextInt();
        for(int i = 1; i <= n; i++)
        {
            String tmp = in.next();
            for(int j = 1; j <= m; j++)
            {
                arr[i][j] = tmp.charAt(j - 1);
            }
        }
        System.out.println(bfs());
    }
}

标签:Java,OJ,AB20,int,y1,ys,x1,public,xt
From: https://blog.csdn.net/GRrtx/article/details/143352150

相关文章

  • 【JavaSE】认识String类,了解,进阶到熟练掌握
    #1024程序员节|征文#下面就让博主带领大家一起解决心中关于String类的疑问吧~~~1.字符串构造:第一种和第二种(有一定的区别,在常量池上)publicstaticvoidmain(String[]args){//使用常量串构造Strings1="hello";System.out.println(s1);//直接newString对象S......
  • 13.Java的IO流
    文件概念文件:保存数据的地方。文件流:文件在程序中是以流的形式来操作的。流:数据在数据源(文件)和程序(内存)之间经历的路径。输入流:数据从数据源(文件)到程序(内存)的路径。输出流:数据从程序(内存)到数据源(文件)的路径。常用操作构造方法方法说明File(Fileparent,......
  • javascript-Web APLs (三)
     事件流指的是事件完整执行过程中的流动路径 说明:假设页面里有个div,当触发事件时,会经历两个阶段,分别是捕获阶段、冒泡阶段 简单来说:捕获阶段是从父到子冒泡阶段是从子到父 实际工作都是使用事件冒泡为主事件捕获DOM.addEventListener(事件类型,事件处......
  • 从零开始的JavaScript基础!
    目录一、JavaScript的概述二、如何在HTML页面中使用JS(一)、行内式 (二)、内嵌式(三)、外链式(四)、基本执行顺序1.从上到下线性执行:2.阻塞行为:(五)、JS输出方式1. alert() 通过浏览器弹出框进行输出 2.document.write() 直接在网页页面中进行输出 3.console.log()......
  • 基于Java+SpringBoot+Mysql实现的古诗词平台功能设计与实现七
    一、前言介绍:1.1项目摘要随着信息技术的迅猛发展和数字化时代的到来,传统文化与现代科技的融合已成为一种趋势。古诗词作为中华民族的文化瑰宝,具有深厚的历史底蕴和独特的艺术魅力。然而,在现代社会中,由于生活节奏的加快和信息获取方式的多样化,古诗词的传播和阅读面临着一定的挑......
  • 基于Java+SpringBoot+Mysql实现的古诗词平台功能设计与实现八
    一、前言介绍:1.1项目摘要随着信息技术的迅猛发展和数字化时代的到来,传统文化与现代科技的融合已成为一种趋势。古诗词作为中华民族的文化瑰宝,具有深厚的历史底蕴和独特的艺术魅力。然而,在现代社会中,由于生活节奏的加快和信息获取方式的多样化,古诗词的传播和阅读面临着一定的挑......
  • Java+Uni-App基于微信小程序的旅游特色民宿预订评价系统/民宿活动系统
    项目介绍对山青水磨民宿管理的流程进行科学整理、归纳和功能的精简,通过软件工程的研究方法,结合当下流行的互联网技术,最终设计并实现了一个简单、易操作的山青水磨民宿App。内容包括系统的设计思路、系统模块和实现方法。系统使用过程主要涉及到管理员、工作者、商家和租客......
  • Java+Uni-App基于微信小程序的洗车服务系统/汽车服务会员积分商城系统
    项目介绍项目介绍基于微信小程序的洗车预约与积分兑换饰品商城系统的开发背景,源自于现代社会对于便捷、高效生活方式的追求以及消费者对个性化服务体验日益增长的需求。随着汽车保有量的不断攀升,洗车服务作为日常汽车保养的基本需求之一,其市场规模日益扩大。然而,传统洗车......
  • Java+Uni-App基于微信小程序的儿童摄影/艺术摄影约拍系统/摄影客片欣赏系统/宝宝满月
    项目介绍基于微信小程序的儿童摄影室管理系统的开发背景,主要源于现代家庭对儿童摄影需求的日益增长以及传统管理方式在效率与便捷性上的不足。随着移动互联网技术的飞速发展,智能手机和微信等社交平台的普及,家长们越来越倾向于通过线上平台预约和管理儿童摄影服务。传统的儿......
  • 基于Java+SpringBoot的社区智慧养老监护管理平台
    关注底部领取源码源码编号:S274源码名称:基于SpringBoot的社区智慧养老监护管理平台用户类型:多角色,用户、护工、后勤人员、体检员、管理员主要技术:Java、Vue、ElementUl、SpringBoot运行环境:Windows/Mac、JDK1.8及以上运行工具:IDEA/Eclipse数 据 库:MySQL5.7及以上版......