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

HWA_03 leetcode874模拟行走机器人

题目map方法的作用解题思路classSolution:defrobotSim(self,commands:List[int],obstacles:List[List[int]])-int:#初始化结果result0#从原点00位置开始出发x0y0#机器人前进的方向#初始方向:正北#0表示向北#1表示向东#2表示向南#3表示向西direction0#机器人是朝北的默认是0#定义四个方向dx[0,1,0,-1]dy[1,0,-1,0]# 障碍物有多个所以需要有⼀个障碍物坐标点集合# 使⽤ 集合 Set 存储障碍物的坐标⽤来检查下⼀步是否受阻# 机器⼈每试图⾛⼀个位置就⽤此位置与障碍物集合列表⾥的坐标进⾏⽐较看是否刚好是障碍物坐标点obstacleSetset(map(tuple,obstacles))#机器人开始行走forcomincommands:## -2向左转 90 度ifcom-2:#1当前方向为正北方向即direction0.向左转90度#来到向西方向即direction需要更新为3#2当前方向不是正北方向即direction 0.向左转90度# ⻄ - 南即 3 - 2# 南 - 东即 2 - 1# 东 - 北即 1 - 0# 即 direction 需要更新为 direction - 1ifdirection0:direction3else:directiondirection-1# direction (direction 0) ? 3 : direction - 1#-1向右转90度elifcom-1:# 1、当前⽅向为正⻄⽅向即 direction 3 向右转 90 度# 来到 向北 ⽅向即 direction 需要更新为 0# 2、当前⽅向【不是】正⻄⽅向即 direction 3 向右转 90 度# 北 - 东即 0 - 1# 东 - 南即 1 - 2# 南 - ⻄即 2 - 3# 即 direction 需要更新为 direction 1ifdirection3:direction0else:directiondirection1# direction (direction 3) ? 0 : direction 1# 1 x 9 向前移动 x 个单位⻓度else:# 没有遇到障碍物⼀直往前⾛ com 个单位⻓度forkinrange(com):if(xdx[direction],ydy[direction])notinobstacleSet:xdx[direction]ydy[direction]resultmax(result,x*xy*y)returnresult注意机器人有指向的(有一个特定的正面)所以#1当前方向为正北方向即direction0.向左转90度#来到向西方向即direction需要更新为3#2当前方向不是正北方向即direction 0.向左转90度# ⻄ - 南即 3 - 2# 南 - 东即 2 - 1# 东 - 北即 1 - 0# 即 direction 需要更新为 direction - 1

相关文章:

HWA_03 leetcode874模拟行走机器人

题目map方法的作用解题思路 class Solution:def robotSim(self, commands: List[int], obstacles: List[List[int]]) -> int:#初始化结果result 0#从原点0,0位置开始出发x0y0#机器人前进的方向#初始方向:正北#0表示向北#1表示向东#2表示向南#3表示向西direction0…...

Bootbox.js终极指南:如何用可复用对话框提升开发效率

Bootbox.js终极指南:如何用可复用对话框提升开发效率 【免费下载链接】bootbox Wrappers for JavaScript alert(), confirm() and other flexible dialogs using Twitters bootstrap framework 项目地址: https://gitcode.com/gh_mirrors/bo/bootbox Bootbox…...

OpenSC2K终极问题解决指南:20个典型开发和使用问题及快速解决方案

OpenSC2K终极问题解决指南:20个典型开发和使用问题及快速解决方案 【免费下载链接】OpenSC2K OpenSC2K - An Open Source remake of Sim City 2000 by Maxis 项目地址: https://gitcode.com/gh_mirrors/op/OpenSC2K OpenSC2K是一款基于JavaScript和WebGL Can…...

如何用Python脚本实现剪映自动化:JianYingApi技术深度解析

如何用Python脚本实现剪映自动化:JianYingApi技术深度解析 【免费下载链接】JianYingApi Third Party JianYing Api. 第三方剪映Api 项目地址: https://gitcode.com/gh_mirrors/ji/JianYingApi 面对视频剪辑中的重复性劳动,你是否渴望解放双手&am…...

goqu性能优化实战:10个提升查询效率的关键技巧

goqu性能优化实战:10个提升查询效率的关键技巧 【免费下载链接】goqu SQL builder and query library for golang 项目地址: https://gitcode.com/gh_mirrors/go/goqu goqu是一款强大的Golang SQL构建和查询库,能够帮助开发者高效地构建和执行SQL…...

OpenSC2K完整开发路线图:打造终极开源城市模拟体验的三大核心方向

OpenSC2K完整开发路线图:打造终极开源城市模拟体验的三大核心方向 【免费下载链接】OpenSC2K OpenSC2K - An Open Source remake of Sim City 2000 by Maxis 项目地址: https://gitcode.com/gh_mirrors/op/OpenSC2K OpenSC2K是一款基于经典游戏《模拟城市200…...

3步突破资源提取瓶颈:让Wallpaper Engine效率提升300%的终极方案

3步突破资源提取瓶颈:让Wallpaper Engine效率提升300%的终极方案 【免费下载链接】repkg Wallpaper engine PKG extractor/TEX to image converter 项目地址: https://gitcode.com/gh_mirrors/re/repkg 在Wallpaper Engine资源开发领域,创作者和开…...

AIGlasses_for_navigation 模型部署的常见错误403 Forbidden排查与解决

AIGlasses_for_navigation 模型部署的常见错误403 Forbidden排查与解决 最近在星图平台上部署了AIGlasses_for_navigation模型,想通过Web API调用一下,结果一发送请求,直接给我返回了个“403 Forbidden”。相信不少朋友在调用自己部署的服务…...

Architect.dev核心组件架构揭秘:深入理解@http、@tables、@events

Architect.dev核心组件架构揭秘:深入理解http、tables、events 【免费下载链接】architect The simplest, most powerful way to build a functional web app (fwa) 项目地址: https://gitcode.com/gh_mirrors/ar/architect Architect.dev 是一个革命性的无服…...

Win10下VSCode安装全攻略:用户版vs系统版到底选哪个?

Win10下VSCode安装全攻略:用户版vs系统版深度解析与实战指南 Visual Studio Code(简称VSCode)作为微软推出的轻量级代码编辑器,凭借其强大的扩展性和跨平台特性,已成为开发者日常工作的标配工具。但在Windows 10环境下…...

用Python和Java复刻经典:Dijkstra最短路径算法从邻接矩阵到完整代码实现

Python与Java双视角解析:Dijkstra最短路径算法的工程实践 当我们需要在电子地图中规划最优路线,或在网络拓扑中寻找最低延迟路径时,图论中的最短路径算法就成为了核心技术支撑。Dijkstra算法作为其中最经典的解决方案之一,其思想简…...

OpenClaw多模态探索:千问3.5-9B处理图文混合任务

OpenClaw多模态探索:千问3.5-9B处理图文混合任务 1. 为什么需要多模态自动化助手 上周我在整理技术文档时遇到一个典型问题:需要根据包含屏幕截图和文字描述的故障报告,编写对应的排查步骤。手动在截图和文本之间来回切换,既低效…...

ChatTTS语音导航优化:车载系统更人性化播报

ChatTTS语音导航优化:车载系统更人性化播报 1. 引言:让车载导航真正"会说话" 你有没有遇到过这样的情况:开车时听着机械冰冷的导航语音,感觉像是在听机器人念经?"前方300米右转"、"请保持直…...

加密货币数据标准化:Cryptofeed如何统一50+交易所的数据格式

加密货币数据标准化:Cryptofeed如何统一50交易所的数据格式 【免费下载链接】cryptofeed Cryptocurrency Exchange Websocket Data Feed Handler 项目地址: https://gitcode.com/gh_mirrors/cr/cryptofeed 在加密货币交易的世界中,数据标准化是一…...

3个步骤实现BetterGenshinImpact多账号协同管理:高效掌控多角色游戏体验

3个步骤实现BetterGenshinImpact多账号协同管理:高效掌控多角色游戏体验 【免费下载链接】better-genshin-impact 📦BetterGI 更好的原神 - 自动拾取 | 自动剧情 | 全自动钓鱼(AI) | 全自动七圣召唤 | 自动伐木 | 自动刷本 | 自动采集/挖矿/锄地 | 一条…...

Hypersistence Utils数组类型深度解析:PostgreSQL ARRAY到Java List的完美映射

Hypersistence Utils数组类型深度解析:PostgreSQL ARRAY到Java List的完美映射 【免费下载链接】hypersistence-utils The Hypersistence Utils library (previously known as Hibernate Types) gives you Spring and Hibernate utilities that can help you get th…...

EdgeConnect三阶段训练详解:从边缘生成到联合优化

EdgeConnect三阶段训练详解:从边缘生成到联合优化 【免费下载链接】edge-connect EdgeConnect: Structure Guided Image Inpainting using Edge Prediction, ICCV 2019 https://arxiv.org/abs/1901.00212 项目地址: https://gitcode.com/gh_mirrors/ed/edge-conn…...

Harpy与Swift项目集成:从Objective-C到现代开发的平滑过渡终极指南

Harpy与Swift项目集成:从Objective-C到现代开发的平滑过渡终极指南 【免费下载链接】Harpy Notify users when a new version of your app is available and prompt them to upgrade. 项目地址: https://gitcode.com/gh_mirrors/ha/Harpy 在iOS应用开发中&am…...

使用Dify快速搭建SmolVLA应用:可视化工作流与Agent编排

使用Dify快速搭建SmolVLA应用:可视化工作流与Agent编排 你是不是也遇到过这样的场景:手里有一个很酷的多模态大模型,比如能看懂图片又能聊天的SmolVLA,但不知道怎么把它变成一个能实际用起来的应用?自己写代码吧&…...

NBIO与标准net/http对比:10倍性能提升的秘密

NBIO与标准net/http对比:10倍性能提升的秘密 【免费下载链接】nbio Pure Go 1000k connections solution, support tls/http1.x/websocket and basically compatible with net/http, with high-performance and low memory cost, non-blocking, event-driven, easy-…...

Notepad++ 插件构想:集成Phi-4-mini-reasoning实现轻量级代码智能

Notepad 插件构想:集成Phi-4-mini-reasoning实现轻量级代码智能 1. 为什么Notepad需要AI插件 作为一个经典的轻量级文本编辑器,Notepad凭借其简洁高效的特点赢得了全球开发者的喜爱。但随着AI技术的快速发展,传统编辑器在代码智能辅助方面的…...

从MySQL DBA视角迁移:在Ubuntu 22.04上快速上手人大金仓KingbaseES的配置与连接

从MySQL DBA视角迁移:在Ubuntu 22.04上快速上手人大金仓KingbaseES的配置与连接 对于长期使用MySQL或Oracle的数据库管理员来说,初次接触国产数据库KingbaseES可能会感到既熟悉又陌生。作为一款成熟的企业级关系型数据库,KingbaseES在语法和功…...

避坑指南:RK3588 HDMI输出分辨率不生效?除了改驱动,你还需要检查这几点

RK3588 HDMI输出分辨率调试实战:从代码修改到系统级排查 最近在调试RK3588平台的HDMI输出时,发现一个有趣的现象:明明按照官方文档和社区教程修改了内核驱动代码,添加了3840x216030Hz的分辨率支持,但系统设置里就是找不…...

千问3.5-2B实战:利用Typora与AI打造智能笔记系统

千问3.5-2B实战:利用Typora与AI打造智能笔记系统 1. 智能笔记系统的价值与痛点 在日常学习和工作中,我们经常面临这样的困境:收集了大量笔记资料,却难以有效组织和利用;记录了许多灵感想法,却无法快速转化…...

CH343芯片驱动安装全攻略:从Windows到Linux再到MacOS,一篇搞定所有系统

CH343芯片跨平台驱动安装实战指南:从Windows到Linux再到MacOS的完整解决方案 第一次拿到基于CH343芯片的开发板时,我对着电脑上"无法识别的USB设备"提示发呆了十分钟。作为一款支持6Mbps高速传输的USB转串口芯片,CH343在嵌入式开发…...

在Ubuntu 22.04上为你的J-Link适配OpenOCD:从源码编译到成功连接实战记录

在Ubuntu 22.04上为J-Link适配OpenOCD:从源码编译到调试连接全流程解析 当你在Ubuntu 22.04环境下进行嵌入式开发时,J-Link调试器配合OpenOCD的组合能提供强大的硬件调试能力。不同于简单的包管理器安装,从源码编译OpenOCD可以确保获得最新功…...

在Windows 10/11上部署ArcGIS 10.2开发环境:Desktop + Engine + .NET SDK 一步到位

在Windows 10/11上部署ArcGIS 10.2开发环境:从兼容性调试到实战开发全指南 当GIS开发者需要在现代化操作系统上构建基于ArcEngine的二次开发环境时,往往会遇到版本兼容性这座"隐形大山"。本文将带您穿越Windows 10/11与ArcGIS 10.2之间的技术…...

WePush邮件推送完全手册:从基础配置到批量发送的完整流程

WePush邮件推送完全手册:从基础配置到批量发送的完整流程 【免费下载链接】WePush 专注批量推送的小而美的工具,目前支持:模板消息-公众号、模板消息-小程序、微信客服消息、微信企业号/企业微信消息、阿里云短信、阿里大于模板短信 、腾讯云…...

MAI-UI-8B保姆级部署教程:5分钟搭建你的第一个GUI智能体

MAI-UI-8B保姆级部署教程:5分钟搭建你的第一个GUI智能体 1. 准备工作 在开始部署MAI-UI-8B之前,我们需要确保系统满足基本要求。这个GUI智能体对硬件有一定要求,但配置过程非常简单。 1.1 系统要求 操作系统:支持Linux/Window…...

【2025最新】基于SpringBoot+Vue的大型商场应急预案管理系统管理系统源码+MyBatis+MySQL

摘要 随着城市化进程的加速和商业综合体的快速发展,大型商场作为人员密集场所,其安全管理面临严峻挑战。传统应急预案管理多依赖纸质文档和人工操作,存在响应速度慢、信息更新滞后、协同效率低等问题。近年来,数字化技术在应急管理…...