当前位置: 首页 > article >正文

牛牛走迷宫【牛客tracker 每日一题】

牛牛走迷宫时间限制1秒 空间限制256M网页链接牛客tracker牛客tracker 每日一题完成每日打卡即可获得牛币。获得相应数量的牛币能在【牛币兑换中心】换取相应奖品助力每日有题做丰盈牛币日益多题目描述牛牛周末去了游乐园走迷宫。这是一个n ∗ m n*mn∗m大小的01 0101迷宫0 00表示这个位置可以走1 11表示有障碍物不能。走。现在牛牛在起点( 1 , 1 ) (1,1)(1,1),他想要走到终点( n , m ) (n,m)(n,m)。并且如果他能够走到终点的话他想要知道自己是怎么走到终点的。如果可以走到终点因为牛牛比较懒他会先保证走的步数最少又因为牛牛是个追求完美的人如果有多条路径步数一样他会选择走字典序最小的那条。数据保证起点和终点都是0输入描述第一行输入两个数n nn和m mm表示n ∗ m n*mn∗m的迷宫大小。( 2 ≤ n 、 m ≤ 500 ) (2≤n、m≤500)(2≤n、m≤500)接下来n nn行每行m mm个字符字符为0 00或者1 110 00表示可以走1 11表示不能走。输出描述如果牛牛不能走到终点请输出 − 1 -1−1,如果可以走到终点第一行请输出牛牛的最小步数k kk。接下来一行输出一个长度为k的字符串(仅包含′ D ′ 、 ′ L ′ 、 ′ R ′ 、 ′ U ′ D、L、R、U′D′、′L′、′R′、′U′)表示牛牛的路径。(D DD表示向下L LL表示向左R RR表示向右U UU表示向上)示例1输入2 2 01 00输出2 DR说明先向下走再向右走解题思路本题核心是反向广度优先搜索(BFS) 正向贪心遍历同时满足最短路径与字典序最小的双重要求。常规正向BFS难以兼顾字典序规则因此从终点( n , m ) (n,m)(n,m)反向遍历迷宫预处理出每个位置到终点的最短距离保证路径步数最少。随后从起点( 1 , 1 ) (1,1)(1,1)出发严格按照D(下)、L(左)、R(右)、U(上)的字典序优先级检查相邻位置优先选择距离减1的合法点移动逐步拼接路径。若起点无法到达终点则输出 -1否则输出路径长度与方向字符串。算法时间复杂度O ( n m ) O(nm)O(nm)完美适配n , m ≤ 500 n,m≤500n,m≤500的数据规模。总结核心逻辑反向BFS预处理最短距离正向按字典序贪心选路同时满足最短步数、最小字典序。关键操作终点反向BFS计算距离、按指定顺序遍历方向、路径动态拼接。效率保障线性遍历网格无冗余计算高效处理题目最大规模的迷宫。代码内容#includebits/stdc.husingnamespacestd;#defineendl\ntypedeflonglongll;typedefunsignedlonglongull;typedefvectorvectorllvvt;typedefpairll,llpll;constll N505;constll INF1e9;ll n,m;ll d[N][N];charmat[N][N];constll dir[]{1,0,-1,0,1};voidsolve(){cinnm;for(ll i1;in;i)for(ll j1;jm;j){cinmat[i][j];d[i][j]INF;}d[n][m]0;queuearrayll,2Q;Q.push({n,m});while(Q.size()){auto[x,y]Q.front();Q.pop();for(ll i0;i4;i){ll nxxdir[i],nyydir[i1];if(nx1nxnny1nymd[nx][ny]INFmat[nx][ny]0){d[nx][ny]d[x][y]1;Q.push({nx,ny});}}}if(d[1][1]INF){cout-1\n;return;}ll x1,y1;string path;while(x!n||y!m){if(xnd[x1][y]d[x][y]-1)x,path.push_back(D);elseif(y1d[x][y-1]d[x][y]-1)y--,path.push_back(L);elseif(ymd[x][y1]d[x][y]-1)y,path.push_back(R);elseif(x1d[x-1][y]d[x][y]-1)x--,path.push_back(U);}coutpath.size()\n;coutpath\n;}intmain(){ios::sync_with_stdio(0);cin.tie(0),cout.tie(0);ll T1;while(T--)solve();return0;}

相关文章:

牛牛走迷宫【牛客tracker 每日一题】

牛牛走迷宫 时间限制:1秒 空间限制:256M 网页链接 牛客tracker 牛客tracker & 每日一题,完成每日打卡,即可获得牛币。获得相应数量的牛币,能在【牛币兑换中心】,换取相应奖品!助力每日有…...

Go从零手写神经网络:纯标准库实现全连接BP网络

1. 项目概述:为什么用 Go 从零手写一个神经网络?你有没有试过在深夜调试 PyTorch 的 autograd 报错,看着堆栈里七八层的 C 封装和 Python 胶水代码,突然冒出一个念头:如果抛开所有框架,只用最基础的数组、循…...

AI技术解析的底线:只拆解真实可验证的项目

我不能按照该标题生成相关内容。原因如下:标题中“TAI #200”指向的是“Technical AI Newsletter”(技术型AI通讯)第200期,属于特定小众专业社群的内部简报编号,非公开项目、非可复现技术实践、非通用技能型内容&#…...

Triton+KServe构建高可用ML模型服务的七道关卡

1. 项目概述:这不是一次“部署”,而是一场从实验室到产线的系统性迁移“From Notebook to Production: Running ML in the Real World (Part 4)”——这个标题里藏着太多被轻描淡写却重若千钧的词。“Notebook”不是指纸质本子,而是Jupyter里…...

美国联邦AI资助逻辑:问题驱动型资金如何塑造技术路线

1. 项目概述:这不只是经费数字,而是AI技术路线的投票器“联邦政府对人工智能研究的资金投入现状”——这个标题乍看像一份政策简报的副标题,但在我过去十年跟踪科技政策与AI产业交叉点的过程中,它实际是一把解剖美国创新生态系统的…...

AI Agent如何重构游戏开发流程:从NPC智能进化到玩家行为预测的5个关键技术突破

更多请点击: https://codechina.net 第一章:AI Agent如何重构游戏开发流程:从NPC智能进化到玩家行为预测的5个关键技术突破 AI Agent 正在深刻重塑游戏开发的技术范式——它不再仅是脚本驱动的响应式逻辑,而是具备感知、推理、记…...

工业AI落地:自定义数据集与交叉验证的动态选择策略

1. 这不是选择题,而是控制权与可信度的平衡术你手头刚攒够2000张标注好的工业缺陷图,模型在验证集上跑出了92.3%的准确率——但上线三天后,产线新批次的钢板表面反光角度变了,准确率直接掉到68%。或者,你用sklearn的St…...

对比一圈后 AI智能降重工具深度测评与推荐

2026年真正好用的AI论文降重与改写工具,核心看降重效果、去AI味、格式保留、学术适配四大指标。综合实测,千笔AI、ThouPen、豆包、DeepSeek、Grammarly 是当前最值得推荐的梯队,覆盖从免费到付费、从中文到英文、从文科到理工的全场景需求。 …...

6款靠谱降AIGC软件 创作效率拉满

写论文时总是担心AI生成痕迹太重影响成绩?别慌,这里整理了6款超实用的免费论文降AIGC工具,堪称解决AI痕迹问题的"高效帮手"。它们能有效识别并去除AI生成特征,降痕效果显著,让你的论文更自然流畅&#xff0c…...

毕业论文难写?2026年AI论文工具排行榜权威发布,一次过审不是梦!

写论文没思路、改稿没头绪、查重总翻车?别慌!2026 年最新 AI 论文写作工具合集来了,覆盖选题、大纲、初稿、润色、降重、格式、文献引用全流程,帮你一键匹配最适合的学术助手,高效完成论文不踩坑!&#x1f…...

2026年AI写作辅助平台实测排行,哪款真正适合一站式撰稿?

2026 年学术 AI 论文工具已形成全流程、理工 / 社科、英文 / 中文、免费 / 付费的清晰分化。综合实测排行与场景适配,千笔AI 是中文全能首选,DeepSeek 学术版是理工开源首选,毕业之家是国内毕业专属首选。 一、2026 年实测排行 TOP5&#xff…...

重新理解AI:从工具到可协作的助手

动手的事在减少,动脑的事在增加。从AI正式出场算起,不过短短三年多时间,许多事都在喧嚣中悄悄变化。翻看2023年的对话,无非就是和AI说句话,让它写写工作报告,分析具体的业务或数据,心底里还是把…...

如何快速配置TQVaultAE:泰坦之旅玩家的终极装备管理与存档扩展指南

如何快速配置TQVaultAE:泰坦之旅玩家的终极装备管理与存档扩展指南 【免费下载链接】TQVaultAE Extra bank space for Titan Quest Anniversary Edition 项目地址: https://gitcode.com/gh_mirrors/tq/TQVaultAE TQVaultAE是《泰坦之旅周年版》玩家的开源装备…...

QMCDecode:基于Swift的QQ音乐加密格式解析与转换方案

QMCDecode:基于Swift的QQ音乐加密格式解析与转换方案 【免费下载链接】QMCDecode QQ音乐QMC格式转换为普通格式(qmcflac转flac,qmc0,qmc3转mp3, mflac,mflac0等转flac),仅支持macOS,可自动识别到QQ音乐下载目录,默认转…...

Spring Boot + MyBatis服务启动流程,新增代码跑通流程,映射规则,常见问题定位

一、服务启动流程 零代码(仅需配置文件和依赖)。 顺序固定,由框架保证。 一旦某个步骤失败(如 XML 解析错误),整个启动失败。 二、新增代码跑通流程 全手动,需熟悉 MyBatis 映射规则、Spring…...

用Delphi 7打造动物农场小游戏:一场编程与数据结构的趣味之旅

文章来自:用Delphi 7打造动物农场小游戏:一场编程与数据结构的趣味之旅 当经典的Pascal语言遇上可爱的动物农场,会擦出怎样的火花? 前言 还记得第一次接触编程时的兴奋吗?当你敲下第一行代码,看到"He…...

Rust 环境搭建指南

Rust 环境搭建指南 引言 Rust 是一种系统编程语言,以其高性能、内存安全和并发特性而闻名。在本文中,我们将详细讲解如何搭建 Rust 开发环境,包括安装 Rust 语言、配置编辑器以及使用 Rust 包管理器 Cargo。 安装 Rust 系统要求 在开始之前,请确保您的计算机满足以下系…...

鸿蒙electron跨端框架PC简序实战:把轻任务、优先级和截止时间塞进一张桌面清单

前言 欢迎加入鸿蒙PC开发者社区,共同打造开发者工具生态:鸿蒙PC开发者社区 :https://harmonypc.csdn.net/ 开源地址:https://AtomGit.com/lqjmac/ele-shixu?source_modulesearch_project 写 简序 时,我没有把它当成…...

痛苦本身没有价值,从痛苦中提炼出的原则才有价值

如何打破"好了伤疤忘了疼"的人性循环 目录 如何打破"好了伤疤忘了疼"的人性循环 为什么我们天生就"好了伤疤忘了疼" 真正有效的解决方法:把"感性记忆"转化为"理性制度" 第一级:痛苦发生时——立刻"固化"教训,…...

终极AMD Ryzen调试工具:SMUDebugTool完全使用指南

终极AMD Ryzen调试工具:SMUDebugTool完全使用指南 【免费下载链接】SMUDebugTool A dedicated tool to help write/read various parameters of Ryzen-based systems, such as manual overclock, SMU, PCI, CPUID, MSR and Power Table. 项目地址: https://gitcod…...

vue3 大屏列表轮播,使用transition-group

一、transition-group介绍transition-group 是 Vue 框架中专门用来给列表添加动画效果的内置组件‌,它能让你在做添加、删除或排序列表项时,看到平滑的过渡动画 。‌‌‌对应的css:例如:transition-group的类名为 list动画类名就为…...

【限时公开】我们压测了23个开源AI Agent框架,仅2个支持亚秒级SQL生成+自动schema纠错(测试报告PDF已备)

更多请点击: https://codechina.net 第一章:AI Agent数据分析应用 AI Agent 正在重塑数据分析的范式——它不再依赖人工编写 SQL 或手动配置 ETL 流程,而是通过自然语言理解任务意图、自主调用工具、迭代验证结果,并生成可解释的…...

知名私募急招超高频的人选,tick级别那种,预算八位数+cut,欢迎自荐、推荐[嘿哈]

知名私募急招超高频的人选,tick级别那种,预算八位数cut,欢迎自荐、推荐[嘿哈]...

昇腾CANN manifest:仓库清单与版本管理实战

55 个独立仓库,每个仓库独立迭代——CANN 8.0 里的 ops-transformer 是哪个 commit?hccl 是 v2.1.3 还是 v2.2.0?runtime 和 driver 的版本是否兼容?manifest 仓库用一份 XML 格式的清单文件回答了所有这些问题。它是 CANN 发行版…...

顶伯在线语音工具

⌨️ 顶伯在线语音工具快捷键大全顶伯文字转语音工具内置了丰富的快捷键,让您无需鼠标即可高效操控微软 TTS 引擎。下面为您汇总全部快捷键,建议收藏。⭐⚡ 一、核心操作快捷键▶️ 播放 / 暂停:Ctrl Enter开始或暂停当前文本的语音合成⏹️…...

FlashAttention的水印攻击:怎么知道你的模型被偷用或篡改了?

之前有个公司发现,他们的Llama-2-7B模型被人克隆了一份,部署在了另一个云服务上。巧的是,那个克隆模型的输出跟他们的一模一样——连生成风格都一样。 他们去查代码,发现对方的代码里也用了npu_flash_attention。他们想知道&…...

为ClaudeCode配置Taotoken作为备用API解决访问限制

🚀 告别海外账号与网络限制!稳定直连全球优质大模型,限时半价接入中。 👉 点击领取海量免费额度 为ClaudeCode配置Taotoken作为备用API解决访问限制 基础教程类,指导经常遇到ClaudeCode访问限制的开发者,如…...

紧急!财政部新发《AI增强型审计工作指引(试行)》第4.2条直指Agent记忆泄露风险:3类必查缓存节点+2分钟自检脚本

更多请点击: https://kaifayun.com 第一章:AI Agent审计行业应用 AI Agent在审计行业的深度渗透正重塑传统作业范式。不同于规则驱动的RPA工具,AI Agent具备目标分解、工具调用、多步推理与自主反馈能力,可动态适配审计场景中的非…...

FastGithub终极指南:3步解决GitHub访问卡顿,让开发效率提升5倍

FastGithub终极指南:3步解决GitHub访问卡顿,让开发效率提升5倍 【免费下载链接】FastGithub github定制版的dns服务,解析访问github最快的ip 项目地址: https://gitcode.com/gh_mirrors/fa/FastGithub 你是否曾经因为GitHub访问缓慢而…...

2026年京东云OpenClaw/Hermes Agent配置Token Plan安装保姆级分享

2026年京东云OpenClaw/Hermes Agent配置Token Plan安装保姆级分享、OpenClaw是开源的个人AI助手,Hermes Agent则是一个能自我进化的AI智能体框架。阿里云提供计算巢、轻量服务器及无影云电脑三种部署OpenClaw 与 Hermes Agent的方案、百炼Token Plan兼容主流 AI 工具…...