力扣498 对角线遍历

问题分析

给定一个 m x n 矩阵,我们需要按照对角线顺序遍历所有元素。对角线遍历的特点是:

  • 每条对角线上元素的行索引与列索引之和为常数
  • 遍历方向交替变化:奇数对角线(从右上到左下),偶数对角线(从左下到右上)

在这里插入图片描述

解决方案

核心思路

  1. 确定对角线常数k:从0到(m-1)+(n-1)
  2. 根据k的奇偶性确定遍历方向
    • k为偶数:从下往上遍历(行索引递减,列索引递增)
    • k为奇数:从上往下遍历(行索引递增,列索引递减)
  3. 确定每条对角线的起始点
    • 当k < min(m, n)时,起始点在矩阵边缘
    • 当k ≥ min(m, n)时,起始点向矩阵内部移动

代码实现

class Solution {public int[] findDiagonalOrder(int[][] mat) {if (mat == null || mat.length == 0) return new int[0];int m = mat.length;int n = mat[0].length;int[] result = new int[m * n];int index = 0;// 遍历所有对角线(k = i + j)for (int k = 0; k < m + n - 1; k++) {if (k % 2 == 0) { // 偶数对角线:从下往上// 确定起始点int i = Math.min(k, m - 1);int j = k - i;// 沿对角线向上遍历while (i >= 0 && j < n) {result[index++] = mat[i][j];i--;j++;}} else { // 奇数对角线:从上往下// 确定起始点int j = Math.min(k, n - 1);int i = k - j;// 沿对角线向下遍历while (j >= 0 && i < m) {result[index++] = mat[i][j];i++;j--;}}}return result;}
}

算法解析

关键步骤详解

在这里插入图片描述

边界处理技巧

  1. 起始点确定
    • 偶数对角线:i = min(k, m-1), j = k - i
    • 奇数对角线:j = min(k, n-1), i = k - j
  2. 遍历终止条件
    • 当行索引或列索引超出矩阵边界时停止
  3. 方向切换
    • 利用k的奇偶性自然切换方向

复杂度分析

指标说明
时间复杂度O(m*n)每个元素访问一次
空间复杂度O(1)除结果数组外无额外空间
遍历效率100%最优解

拓展思考

变体问题

  1. Z字形打印矩阵
  2. 螺旋矩阵遍历
  3. 对角线求和问题

总结

对角线遍历问题展示了如何通过观察矩阵的数学特性(行索引+列索引=常数)来设计高效算法。关键在于:

  1. 识别对角线遍历的数学规律
  2. 巧妙处理遍历方向的交替变化
  3. 精确控制边界条件

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

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

相关文章

【单例模式】

概述一个类不管创建多少次对象&#xff0c;永远只能得到该类型的一个对象的实例。常用到的比如日志模块 &#xff0c;数据库模块饿汉&#xff1a;在类加载时就创建单例对象&#xff0c;因此它是线程安全的&#xff0c;因为对象的创建在程序启动时就已经完成&#xff0c;不存在多…

Unity开发如何实现换装技术

一、3D换装方案SkinnedMeshRenderer组件替换&#xff08;最常用&#xff09;适用场景&#xff1a;角色需要保持骨骼动画&#xff0c;更换服装/武器等实现步骤&#xff1a;1.准备模型&#xff1a;所有服装需使用相同骨骼结构&#xff08;建议在建模软件中绑定到同一套骨骼&#…

RabbitMQ面试精讲 Day 29:版本升级与平滑迁移

【RabbitMQ面试精讲 Day 29】版本升级与平滑迁移 在“RabbitMQ面试精讲”系列的第29天&#xff0c;我们聚焦于一个在中高级系统架构与运维面试中极具分量的话题——RabbitMQ的版本升级与平滑迁移。随着业务发展和RabbitMQ自身功能演进&#xff08;如从经典集群到Quorum队列、从…

Python-机器学习概述

​​一、人工智能三大概念​​ ​​人工智能&#xff08;AI&#xff09;​​ 定义&#xff1a;使用计算机模拟或代替人类智能的研究领域 目标&#xff1a;像人类一样思考&#xff08;理性推理&#xff09;、行动&#xff08;决策执行&#xff09; 别名&#xff1a;仿智 ​​…

GIT压缩提交,将多个已经push的commit提交,合并成一个

1.选中要合并的提交2.选中后右键选着Squash Committs3.重新编辑提交信息4.操作完成后不能pull,要强制pushgit push --force

(多线程)线程安全和线程不安全 产生的原因 synchronized关键字 synchronized可重入特性死锁 如何避免死锁 内存可见性

线程安全问题产生原因 线程安全问题主要发生在多线程环境下&#xff0c;当多个线程同时访问共享资源时&#xff0c; 如果没有采取适当的同步措施&#xff0c;就可能导致数据不一致或程序行为异常1.[根本]操作系统对于线程的调度是随机的.抢占式执行&#xff0c;这是线程安全问题…

defineCustomElement 的局限性及重载需求分析

一、defineCustomElement 的核心局限性 Vue 的 defineCustomElement 虽然实现了 Vue 组件到 Web Components 的转换,但在跨框架/跨语言场景下存在以下关键局限,这也是你的项目需要重载其返回构造器的根本原因: 1. 框架间事件模型不兼容 Vue 事件机制:依赖 $emit 转换的 C…

如何在前端开发中应用AI技术?

一、AI 辅助前端开发流程&#xff08;提效工具&#xff09;智能代码生成与补全使用 AI 编程工具&#xff08;如 GitHub Copilot、Cursor、Amazon CodeWhisperer&#xff09;实时生成代码片段&#xff0c;支持 HTML、CSS、JavaScript、React/Vue 等框架语法。例如&#xff0c;输…

极海发布APM32F425/427系列高性能MCU:助力工业应用升级

聚焦工业4.0及能源管理应用对主控MCU的高性能需求&#xff0c;极海正式发布APM32F425/427系列高性能拓展型MCU&#xff0c;集合运算性能、ADC性能、Flash控制器性能与通信接口四大维度革新&#xff0c;进一步增强了EMC性能&#xff0c;重新定义Cortex-M4F内核在复杂工业场景下的…

JSX深度解析:不是HTML,胜似HTML的语法糖

JSX深度解析&#xff1a;不是HTML&#xff0c;胜似HTML的语法糖 作者&#xff1a;码力无边大家好&#xff01;我是依然在代码世界里乘风破浪的码力无边。欢迎回到我们的《React奇妙之旅》第二站&#xff01; 在上一篇文章中&#xff0c;我们成功地用Vite启动了第一个React应用&…

大模型应用新趋势:从思维链到 HTML 渲染的破局之路

一、大模型交互范式的演进&#xff1a;从 Prompt 工程到思维链革新早期的 Prompt 工程曾面临 “模型特异性” 困境 —— 精心设计的提示词在不同模型上效果迥异。但随着 ** 思维链&#xff08;CoT&#xff09;** 技术的成熟&#xff0c;这一局面正在改变。从 OpenAI o1 的隐式整…

从“找不到”到“秒上手”:金仓文档系统重构记

你是否曾在浩如烟海的产品手册中迷失方向&#xff1f;是否为了一个关键参数翻遍十几页冗余说明&#xff1f;是否对时灵时不灵的搜索功能感到抓狂&#xff1f;甚至因为漫长的加载时间而失去耐心&#xff1f;我们懂你!这些曾困扰金仓用户的文档痛点&#xff0c;从现在起&#xff…

【开源项目分享】可监控电脑CPU、显卡、内存等硬件的温度、功率和使用情况

系列文章目录 【开源项目分享】可监控电脑CPU、显卡、内存等硬件的温度、功率和使用情况 &#xff08;一&#xff09;开源的硬件监控工具 LibreHardwareMonitor &#xff08;二&#xff09;LibreHardwareMonitor 分层架构设计 &#xff08;三&#xff09;LibreHardwareMonitor…

帕累托优化:多目标决策的智慧与艺术

本文由「大千AI助手」原创发布&#xff0c;专注用真话讲AI&#xff0c;回归技术本质。拒绝神话或妖魔化。搜索「大千AI助手」关注我&#xff0c;一起撕掉过度包装&#xff0c;学习真实的AI技术&#xff01; 在相互冲突的目标中寻找最优平衡 ✨ 1. 帕累托优化概述 帕累托优化&a…

#Linux内存管理学以致用# 请你根据linux 内核struct page 结构体的双字对齐的设计思想,设计一个类似的结构体

Linux struct page 的双字对齐设计思想1.双字对齐&#xff08;8字节对齐&#xff09;&#xff1a;确保struct page的大小是sizeof(long)的整数倍&#xff08;通常8字节&#xff09;&#xff0c;便于CPU高效访问。减少内存碎片&#xff0c;提高缓存行&#xff08;Cache Line&…

白酒变局,透视酒企穿越周期之道

今年以来&#xff0c;在科技股的带动下&#xff0c;A股市场表现十分突出&#xff0c;近期沪指甚至创出了十年来新高。然而&#xff0c;在这轮市场的表现中&#xff0c;曾经被资金热捧的白酒板块&#xff0c;却显得有些沉寂。业绩层面&#xff0c;从目前已披露的白酒上市公司半年…

智慧园区:从技术赋能到价值重构,解锁园区运营新范式

在数字化浪潮席卷产业的当下&#xff0c;智慧园区已从 “概念蓝图” 落地为 “实战方案”&#xff0c;其核心逻辑既源于技术的突破性应用&#xff0c;也扎根于企业的实际需求&#xff0c;更顺应着行业发展的未来趋势&#xff0c;成为驱动园区从传统管理向智能化运营升级的核心引…

模运算(密码学/算法)

1 什么是模运算 模运算的概念 模运算是一种算术运算&#xff0c;常写作a mod n&#xff0c;表示整数a除以正整数n后的余数。 模数是模运算中的除数n&#xff0c;它决定了结果的范围。 公式表达&#xff1a; 对于任意整数a和正整数n&#xff0c;可以将a表示为&#xff1a;a qn …

海康相机的 HB 模式功能详解

海康相机的 HB 模式是一种无损压缩技术,全称为High Bandwidth 模式,主要用于提升工业相机在高速场景下的数据传输效率。其核心原理是通过硬件级无损压缩算法对原始图像数据进行压缩,在不损失画质的前提下减少数据量,从而突破千兆网络的带宽限制,实现更高的行频和传输帧率。…

electron应用开发:命令npm install electron的执行逻辑

我们来彻底解析 npm install electron 这个命令背后的完整执行逻辑。这是一个非常精妙的过程&#xff0c;远不止下载一个简单的 JavaScript 包那么简单。理解了它&#xff0c;你就能透彻地明白 Electron 开发环境的运作原理&#xff0c;并能轻松解决各种安装问题。 npm instal…