3459. 最长 V 形对角线段的长度

Problem: 3459. 最长 V 形对角线段的长度

文章目录

  • 思路
  • 解题过程
  • 复杂度
  • Code

思路

深度优先搜索 + 记忆数组

解题过程

主函数和先遍历从每一个1开始搜索,并枚举每一个方向进入dfs,dfs先检查是否遍历过,然后枚举下一个可以走的方向,最后返回最值即可。

复杂度

  • 时间复杂度: O(n2)O(n^2)O(n2)
  • 空间复杂度: O(n2)O(n^2)O(n2)

Code

class Solution {
public:int maxlen = 0;array<int, 4> dx{1, 1, -1, -1};array<int, 4> dy{1, -1, -1,  1};int m, n;vector<vector<int>> grid;int memo[505][505][3][2][4];int dfs(int px, int py, int pn, int changed, int drec) {if (memo[px][py][pn][changed][drec] != -1) return memo[px][py][pn][changed][drec];int need = (pn == 2 ? 0 : 2);int best = 1;int nx = px + dx[drec], ny = py + dy[drec];if (nx >= 0 && nx < n && ny >= 0 && ny < m && grid[nx][ny] == need) {best = max(best, 1 + dfs(nx, ny, need, changed, drec));}if (!changed) {int nd = (drec + 1) % 4;int tx = px + dx[nd], ty = py + dy[nd];if (tx >= 0 && tx < n && ty >= 0 && ty < m && grid[tx][ty] == need) {best = max(best, 1 + dfs(tx, ty, need, 1, nd));}}memo[px][py][pn][changed][drec] = best;if (best > maxlen) maxlen = best;return best;}int lenOfVDiagonal(vector<vector<int>>& ggrid) {grid = ggrid;n = grid.size();m = grid[0].size();maxlen = 0;memset(memo, -1, sizeof(memo));for (int i = 0; i < n; ++i) {for (int j = 0; j < m; ++j) {if (grid[i][j] == 1) {for (int k = 0; k < 4; ++k) {dfs(i, j, 1, 0, k);}}}}return maxlen;}
};

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如若转载,请注明出处:http://www.pswp.cn/diannao/97003.shtml
繁体地址,请注明出处:http://hk.pswp.cn/diannao/97003.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

Unity 串口通信

可以通过计算机管理->设备管理器&#xff0c;查看端口串口通讯&#xff0c;通常是指的通过计算机或其他设备上的串行端口实现数据传输的过程。 定义与特点&#xff1a;串口通讯是按位&#xff08;bit&#xff09;发送和接收字节的通信方式&#xff0c;它将数据一位一位地顺序…

ArcGIS JSAPI 高级教程 - 创建渐变色材质的自定义几何体

ArcGIS JSAPI 高级教程 - 创建渐变色材质的自定义几何体核心代码完整代码在线示例工作中遇到一个比较复杂的功能&#xff0c;其中用到渐变色&#xff0c;于是研究了一下&#xff0c;发现虽然 JS API 不直接支持渐变色&#xff0c;但是也可以自定义创建渐变色&#xff0c;通过 M…

不增加 GPU,首 Token 延迟下降 50%|LLM 服务负载均衡的新实践

作者&#xff1a;钰诚 简介 传统的负载均衡算法主要设计用于通用的 Web 服务或微服务架构中&#xff0c;其目标是通过最小化响应时间、最大化吞吐量或保持服务器负载平衡来提高系统的整体效率&#xff0c;常见的负载均衡算法有轮询、随机、最小请求数、一致性哈希等。然而&am…

《Linux内存管理:实验驱动的深度探索》【附录】【实验环境搭建 7】【使用buildroot方式构建文件系统】

1. 使用Buildroot 构建的优势 使用 Buildroot 构建 rootfs 的优点在于 快速、简洁、可裁剪、可重复&#xff0c;特别适合 中小型嵌入式 Linux 项目&#xff08;如车机、路由器、工业控制设备、IoT 网关&#xff09;。它帮助开发者避免繁琐的手动编译和集成工作&#xff0c;专注…

一洽客服系统:网页咨询入口设置

一洽客服系统提供了灵活的网页咨询入口设置&#xff0c;旨在为用户提供多样化的咨询类别选择&#xff0c;并根据用户的需求接入指定的路由线路。以下是该功能的详细说明&#xff1a;一、网页咨询入口设置针对用户的不同业务提供不同的咨询类别选择&#xff0c;用户选择业务后接…

Apache Flink错误处理实战手册:2年生产环境调试经验总结

作者&#xff1a;_Naci Simsek 前言 在流处理领域&#xff0c;Apache Flink 已经成为企业级实时数据处理的首选框架。然而&#xff0c;在生产环境中&#xff0c;开发者和运维人员经常会遇到各种看似神秘的问题。基于过去两年中大量客户在真实场景中的使用案例&#xff0c;可以观…

嵌入式开发学习 C++:day01

C概述 C诞生 1972年前后&#xff0c;计算机先驱丹尼斯里奇开始设计C语言并用它来重写Unix系统&#xff0c;里奇的这个决定催生了计算机领域最石破天惊的两门重炮:Unix和C&#xff0c;这两者都是IT产业中鼻祖级的存在&#xff0c;Unix是现代苹果系统和Linux系统的最初来源&#…

LeaferJS创建支持缩放、平移的画布,并绘制简单图形

文章目录介绍原生JS使用LeaferJS的简单示例原生JS使用LeaferJS并支持缩放平移画布Vue中使用LeaferJS并支持缩放平移介绍 LeaferJS官网&#xff1a;https://www.leaferjs.com/ 官方快速上手的教程地址&#xff1a;https://www.leaferjs.com/ui/guide/install/ui/start.html 原…

JumpServer 堡垒机部署与 SSH 公钥接入服务器教程

前言&#xff1a;在企业运维场景中&#xff0c;服务器的安全访问与操作管控至关重要。JumpServer 作为开源堡垒机的典型代表&#xff0c;凭借集中管控、权限精细分配、操作全链路审计等核心能力&#xff0c;成为保障运维安全合规的关键工具。 无论是中小企业简化运维权限管理&a…

TensorFlow 面试题及详细答案 120道(21-30)-- 模型构建与神经网络

《前后端面试题》专栏集合了前后端各个知识模块的面试题,包括html,javascript,css,vue,react,java,Openlayers,leaflet,cesium,mapboxGL,threejs,nodejs,mangoDB,SQL,Linux… 。 前后端面试题-专栏总目录 文章目录 一、本文面试题目录 21. TensorFlow中构建神经…

Qt图片上传系统的设计与实现:从客户端到服务器的完整方案

文章目录系统架构概览核心组件解析1. ImageUploadWorker&#xff1a;上传任务的执行者关键方法解析2. ImageUploadManager&#xff1a;线程的"指挥官"3. ImageUploader&#xff1a;网络通信的"信使"4. 服务器端&#xff1a;图片的"收纳箱"关键技…

MySQL InnoDB vs MyISAM

MySQL 两种引擎&#xff08;InnoDB vs MyISAM&#xff09;核心区别事务与锁机制‌‌特性‌‌InnoDB‌‌MyISAM‌‌事务支持‌支持 ACID 事务&#xff08;原子性、一致性、隔离性、持久性&#xff09;&#xff0c;适用于需强数据一致性的场景&#xff08;如金融交易&#xff09;…

软件定义汽车(SDV)调试——如何做到 适配软件定义汽车(SDV)?(上)

我是穿拖鞋的汉子,魔都中坚持长期主义的汽车电子工程师。 老规矩,分享一段喜欢的文字,避免自己成为高知识低文化的工程师: 做到欲望极简,了解自己的真实欲望,不受外在潮流的影响,不盲从,不跟风。把自己的精力全部用在自己。一是去掉多余,凡事找规律,基础是诚信;二是…

windows下 docker desktop 清理ext4.vhdx文件 并缩小ext4.vhdx文件

1、路径C:\Users\Administrator\AppData\Local\Docker\wsl\dataext4.vhdx 清理之前30多G&#xff0c;现在只有不到2个G2、清理命令# 1、清‌清理悬空镜像和缓存‌ docker image prune -f # 删除未被引用的镜像层 docker builder prune -f # 清理构建缓存# 2、压缩虚拟磁盘&a…

超越ChatBI!深度解析衡石HENGSHI SENSE 6.0如何实现全流程AI赋能

在数据智能领域风起云涌的2025年&#xff0c;“ChatBI”已成为一个炙手可热却又令人疲惫的概念。市场上充斥着各式各样的问答式BI工具&#xff0c;它们虽然带来了交互的新颖体验&#xff0c;却往往局限于“问答”这一单一环节&#xff0c;无法解决数据从整合到洞察的全链路痛点…

Apple Silicon Mac 上解决 Docker 平台不匹配和 QEMU 段错误问题

问题概述 许多用户在 Apple Silicon (M1/M2) Mac 上尝试运行 W3AF Docker 镜像时遇到了以下错误: WARNING: The requested images platform (linux/amd64) does not match the detected host platform (linux/arm64/v8) and no specific platform was requested qemu: uncau…

如何借助文档控件 TX Text Control 轻松优化 PDF 文件大小?

在数字文档的日常使用中&#xff0c;PDF 文件的体积大小直接影响存储空间、传输速度和打开体验。尤其是在包含大量图片、图表或字体资源的文档中&#xff0c;文件往往会变得非常庞大。 文档处理控件TX Text Control 为开发者提供了多种可配置的工具与策略&#xff0c;帮助在不同…

[身份验证脚手架] 前端认证与个人资料界面

第2章&#xff1a;前端认证与个人资料界面 欢迎回来&#xff0c;未来的Web开发者&#xff01;在前一章中&#xff0c;我们学习了breeze:install命令如何为您的Laravel应用设置用户认证基础。您选择了一个"前端技术栈"(如Blade、React、Vue或Livewire)并运行了一些命…

RabbitMQ、RocketMQ 和 ActiveMQ 三种主流消息队列的详细部署安装指南

RabbitMQ、RocketMQ 和 ActiveMQ 三种主流消息队列的详细部署安装指南 RabbitMQ、RocketMQ 和 ActiveMQ 三种主流消息队列的详细部署安装指南。 一、RabbitMQ 部署安装 RabbitMQ 用 Erlang 语言编写,推荐使用官方提供的 Docker 镜像或包管理器安装。 方法一:使用 Docker (…

vue新增用户密码框自动将当前用户的密码自动填充的问题

1.问题 新增店铺的时候&#xff0c;设置管理员账号&#xff0c;输入框已将当前登录用户的密码填充上了解决方式 在el-input输入框类型为password的上增加参数autocomplete“new-password”<el-form-item :label"$t(storeList.password)" prop"shopUserPasswo…