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

1424.对角线遍历

题目来源:力扣

此解法是在力扣官网上找到的

原作者:Storm

链接:1424. 对角线遍历 II - 力扣(LeetCode)

加上了自己的理解与分析便于理解代码


 //    对角线遍历2
 //    给你一个列表 nums ,里面每一个元素都是一个整数列表。
 //    请你依照下面各图的规则,按顺序返回 nums 中对角线上的整数。
 ​
 //    每一个子列表代表一行,不同行的长度可能不同
         public static int[] findDiagonalOrder(List<List<Integer>> nums) {
         List<int[]> list = new ArrayList<int[]>();
         int rows = nums.size();
         for (int i = 0; i < rows; i++) {
             List<Integer> rowList = nums.get(i);
             int cols = rowList.size();
             for (int j = 0; j < cols; j++) {
                 int num = rowList.get(j);
                 list.add(new int[]{i + j, j, num});
             }
         }
         Collections.sort(list, (a, b) -> {
             if (a[0] != b[0]) {
                 return a[0] - b[0];
             } else {
                 return a[1] - b[1];
             }
         });
         int size = list.size();
         int[] order = new int[size];
         for (int i = 0; i < size; i++) {
             order[i] = list.get(i)[2];
         }
         return order;
     }

代码详细解释

1. 定义类和方法
 class Solution {
     public int[] findDiagonalOrder(List<List<Integer>> nums) {
  • 定义了一个名为 Solution 的类。

  • 定义了一个公共方法 findDiagonalOrder,它接收一个嵌套列表 nums 作为参数,并返回一个整数数组。

2. 创建存储元素信息的列表
List<int[]> list = new ArrayList<int[]>();
 int rows = nums.size();
  • 创建了一个 List<int[]> 类型的 list,用于存储每个元素的信息。每个元素信息用一个长度为 3 的整数数组表示,分别存储 i + jj 和元素值。(用于后面排序)

  • rows 变量存储了嵌套列表的行数。

3. 遍历嵌套列表
 for (int i = 0; i < rows; i++) {
     List<Integer> rowList = nums.get(i);
     int cols = rowList.size();
     for (int j = 0; j < cols; j++) {
         int num = rowList.get(j);
         list.add(new int[]{i + j, j, num});
     }
 }
  • 外层循环遍历每一行,获取当前行的子列表 rowList 以及当前行的列数 cols

  • 内层循环遍历当前行的每一列,获取当前元素 num,并将 [i + j, j, num] 存储到 list 中。

4. 对元素信息列表进行排序(重点排序)
Collections.sort(list, (a, b) -> {
     if (a[0] != b[0]) {
         return a[0] - b[0];
     } else {
         return a[1] - b[1];
     }
 });
  • 使用 Collections.sort 方法对 list 进行排序。

  • 排序规则是:先比较元素的 i + j 值(即 a[0]b[0]),若不相等,则按照 i + j 从小到大排序;若相等,则比较列索引 j(即 a[1]b[1]),按照列索引从小到大排序。

5. 创建结果数组并存储排序后的元素
 int size = list.size();
 int[] order = new int[size];
 for (int i = 0; i < size; i++) {
     order[i] = list.get(i)[2];
 }
  • size 存储了 list 的大小,即元素的总数。

  • 创建一个长度为 size 的整数数组 order

  • 遍历 list,将每个元素信息数组中的第三个元素(即元素值)存储到 order 数组中。

6. 返回结果数组
 return order;
  • 返回存储排序后元素的数组 order

复杂度分析

  • 时间复杂度O(Nlog**N),其中 N 是嵌套列表中元素的总数。主要时间开销在于对 list 进行排序。

  • 空间复杂度O(N),主要空间开销在于存储元素信息的 list 和结果数组 order

有更好的解法,欢迎评论或私信

相关文章:

  • 322 零钱兑换
  • 【大模型基础_毛玉仁】4.4 低秩适配方法
  • RocketMQ 4.x、5.x 性能对比
  • 绩效考核如何从形式化任务升级为公司战略工具?
  • 2025.3.25
  • 基于CondLaneNet论文和全卷积分割头的车道线head设计
  • QML输入控件: Dial基本用法与样式定制(1)
  • 【机器学习】imagenet2012 数据预处理数据预处理
  • K8S学习之基础五十二:k8s配置jenkins
  • Vite 与 Nuxt 深度对比分析
  • 软件设计模式-第一章
  • 数据源为postgres的多表关联flink开发需求,开发思路
  • jmeter通过json提取器获取接口返回token(超详细)
  • 3.1.2 内存池
  • Java.util包之Java.util.List接口
  • 【msyql】LInux安装Mysql
  • kubernetes高级应用之初始化容器
  • 第 6 章 | 区块链预言机操控与闪电贷攻击全解析
  • 数据结构之队列的链式结构-初始化-判断队列是否为空-入队-出队-获取队头元素
  • 八目导航 version:1.2
  • 智利观众也喜欢上海的《好东西》
  • A股三大股指低收:银行股再度走强,两市成交11920亿元
  • 甘肃省政府原副省长赵金云被决定逮捕
  • 大四本科生已发14篇SCI论文?学校工作人员:已记录汇报
  • 视频|漫画家寂地:古老丝路上的文化与交流留下的独特印记
  • 明查|这是“C919迫降在农田”?实为飞机模型将用于科普体验