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

十四届蓝桥杯STEMA考试Python真题试卷第二套第五题

来源:十四届蓝桥杯STEMA考试Python真题试卷第二套编程第五题
本题属于迷宫类问题,适合用DFS算法解决,解析中给出了Python中 map() 和列表推导式的应用技巧。最后介绍了DFS算法的两种常见实现方式——递归实现、栈实现,应用场景——迷宫类问题、图的连通性、树的遍历、拓朴排序、排列组合,以及主要优缺点。

题目描述

有一个 N*M 的矩阵,且矩阵中的每个方格都有一个整数(0≤整数≤100),小蓝需要按照以下要求从矩阵中找出一条最长的移动路线,且输出最长路线的长度(1 个方格为 1 个长度)。

要求:
1.小蓝可以从矩阵中任意一个方格开始向它的上、下、左、右相邻的任意一个方格移动,且移动的路线不能有交叉;
2.小蓝每次所要移动到的方格中的整数都要小于当前所在方格中的整数(如当前所在的方格中的整数为 3,那么可以移动到数字为 0,1,2 的格子里,不可以移动到数字为 3,4,5…的格子里);

例如:
N=3,M=3,矩阵方格如下:
在这里插入图片描述
最长路线为 4 -> 3 -> 2 -> 1,故路线长度为 4。

输入描述:
第一行输入两个正整数 N,M(1<N≤1000,1<M≤1000),N 表示矩阵的行数,M 表示矩阵的列数,两个正整数之间以一个空格隔开
第二行开始输入 N 行,每行包含 M 个整数(0≤每个整数≤100),表示每个方格中的整数,每个整数之间以一个空格隔开

输出描述:
输出一个整数,表示最长路线的长度

样例输入:

3 3
1 1 3
2 3 4
1 1 1

样例输出:

4

参考答案

def longestPath(matrix):rows, cols = len(matrix), len(matrix[0])max_length = 0def dfs(i, j, visited):# 1. 基本状态: 当前位置已经计入路径长度current_length = 1# 2. 定义四个移动方向: 上、下、左、右directions = [(-1, 0), (1, 0), (0, -1), (0, 1)]# 3. 遍历每个可能的移动方向for di, dj in directions:# 计算新位置的坐标ni, nj = i + di, j + dj# 4. 检查移动的合法性if (0 <= ni < rows                      # 检查行是否越界and 0 <= nj < cols                  # 检查列是否越界and (ni, nj) not in visited         # 检查是否已访问and matrix[ni][nj] < matrix[i][j]   # 检查数字是否更小):# 5. 递归探索visited.add((ni, nj))   # 标记已访问# 计算包含当前位置的最长路径current_length = max(current_length, 1 + dfs(ni, nj, visited))visited.remove((ni, nj))            # 回溯,移除访问标记return current_length# 6. 遍历矩阵中的每个位置作为起点for i in range(rows):for j in range(cols):visited = {
http://www.lryc.cn/news/477077.html

相关文章:

  • 虚拟机 Ubuntu 扩容
  • 内网远程连接解决方案【Frp】
  • 浙江欧瑞雅装饰材料有限公司:空间的艺术,定制的智慧!
  • jfrog artifactory oss社区版,不支持php composer私库
  • 华为OD机试真题-用户调度问题-2024年OD统一考试(E卷)
  • 前端与后端长连接 方法
  • 建议AI产品经理面试准备到这个程度再去
  • 智能交通的未来:深度学习如何改变车辆检测游戏规则
  • 家具制造的效率与美观并重,玛哈特矫平机让家具产品更具竞争力。
  • 交叉编译gcc
  • [VUE]框架网页开发1 本地开发环境安装
  • 【MySQL】——数据库恢复技术
  • 乡村景区一体化系统(门票,餐饮,便利店,果园,娱乐,停车收费
  • 从零开始的c++之旅——继承
  • 电路知识的回顾
  • 使用 `Celery` 配合 `RabbitMQ` 作为消息代理,实现异步任务的调度、重试、定时任务以及错误监控等功能
  • react-router与react-router-dom的区别
  • 【研究生必看】把选题和文献交给AI,轻松搞定毕业论文!
  • Android中同步屏障(Sync Barrier)介绍
  • 真·香!深度体验 zCloud 数据库云管平台 -- DBA日常管理篇
  • 优雅的遍历JSONArray,获取里面的数据
  • C#:强大而优雅的编程语言
  • 一个由Deno和React驱动的静态网站生成器
  • Python pyautogui库:自动化操作的强大工具
  • 【HTML】——VSCode 基本使用入门和常见操作
  • 从0开始搭建一个生产级SpringBoot2.0.X项目(八)SpringBoot 使用Redis
  • Ubuntu20.04两种安装及配置中文界面、输入法、换源、共享文件夹实现,及注意事项
  • 后端Java学习:springboot之文件上传(阿里云OSS存储)
  • python通过lunarcalendar库使用农历日期
  • MySQL高级--范式与反范式