1. Job Roadmap
  2. Home
  3. Problem Set
  4. codenotelist
  5. Forum
  6. course
  7. Shore Share Sessions
  8. Record
  1. Login
  2. Sign Up
  3. Language
    1. English
    2. 한국어
    3. 简体中文
    4. 正體中文
    ZhContent TextSol AI分析

解题思路

这道题要求对于地图上的每个位置,求它到最近字符 ′0′'0'′0′ 的最少步数。每次只能向上、下、左、右走一步,因此本质上是在网格图上求每个点到最近多个起点的最短路。

这里使用的相关算法是多源广度优先搜索,也就是多源 BFSBFSBFS。

核心思路如下:

先把所有值为 ′0′'0'′0′ 的位置同时加入队列,并把这些位置的距离初始化为 000。因为这些点本身就是目标点,所以它们到最近 ′0′'0'′0′ 的距离就是 000。

P4667.第2题-该回家了

    1000ms Tried: 20 Accepted: 12 Difficulty: 3 所属公司 : 蚂蚁
    算法与标签>BFS

题目内容

给定一张由 nnn 行、mmm 列组成的地图。用字符,′0′'0'′0′ 表示天才同学的别墅位置,用字符 ′1′'1'′1′,表示其他位置对于地图上的每一个位置,定义其到最近别墅的距离为:从该位置出发,每次可以向上、下、左、右四个方向走一步(曼哈顿距离的一步),到达任意一个,′0′'0'′0′ 所需要的最少步数。若该位置本身就是,′0′'0'′0′,则距离为 000 。

输入描述

在一行上输入两个整数 n,m(1≤n,m≤103)n,m(1≤n,m≤10^3)n,m(1≤n,m≤103) ,表示地图的行数与列数此后 nnn 行,每行输入一个长度为 mmm 的字符串 sis_isi​,仅由字符,′0′'0'′0′ 和 ′1′'1'′1′,组成。保证至少存在一个位置为 ′0′'0'′0′。

输出描述

输出 nnn 行。第 iii 行输出 mmm 个整数,分别表示第 iii 行每个位置到最近 ′0′'0'′0′ 的最短步数。相邻整数之间使用一个空格分隔。

样例1

输入

3 4
0111
0011
1111

输出

0 1 2 3
0 0 1 2
1 1 2 3

说明

对于样例中第 111 行第 111 列位置是 ′0′'0'′0′,因此距离为 000 ;第 111 行第 444 列到最近 ′0′'0'′0′ 的最短路径长度为 333 (一种方法是向左走三步)。

登录后即可使用 AI 分析。

模式
倒计时时长
:

最长 10 小时 59 分;应用后按此时长重新开始。

提示:点击提交记录在左侧题面区域查看详情
题库
AI分析设置
留空使用官方API Key,每天有次数限制(自定义API Key仅限会员和管理员使用,不限次数)
会员和管理员可切换模型;切到 Kimi/智谱/通义/豆包时需填写对应供应商 API Key
升级会员,可将运行与提交冷却时间缩短至 1 秒起

Status

  • Judging Queue
  • Service Status

Development

  • Open Source

Support

  • Help
  • Contact Us

About

  • About
  • Privacy
  • Terms of Service
  • Copyright Complaint
  1. Language
    1. English
    2. 한국어
    3. 简体中文
    4. 正體中文
  2. Legacy mode
  3. Theme
    1. Light
    2. Dark
  1. 京ICP备2025123107号-1
  2. Worker 2, 36ms
  3. Powered by Hydro v5.0.0-beta.18 Community
CLOSE


ScanQRCodePrompt

请使用微信扫描下方二维码完成注册

Forgot password or username?