[M模拟] lc3446. 按对角线进行矩阵排序(对角线遍历+公式推导+模板题)

文章目录

    • [1. 题目来源](#1. 题目来源)
    • [2. 题目解析](#2. 题目解析)

1. 题目来源

链接:3446. 按对角线进行矩阵排序

题单:

  • 待补充

2. 题目解析

2025年03月25日18:10:00

矩形的三种遍历方式吧:

  • 行遍历
  • 列遍历
  • 对角线遍历

其中对角线遍历在 八皇后 问题中还遇见过,正对角线,反对角线,两种。其实就是对角线上的点的 和、差 是有一定规律的。

这里简单写一个对角线遍历的模板吧,其他的都是同理。主要学习以下几点:

  • 公式化推导。
  • 遍历,就是需要得到最大值、最小值即可。

视屏讲解参考:

具体的分析,见下图:



  • 时间复杂度 : O ( n m ) O(nm) O(nm)
  • 空间复杂度 : O ( 1 ) O(1) O(1)

go 复制代码
func sortMatrix(grid [][]int) [][]int {
    n, m := len(grid), len(grid[0])
    for k := 1; k < m + n; k ++ {
        minJ := max(0, m - k)
        maxJ := min(m - 1, n - 1 - k + m)

        col := []int{}
        for j := minJ; j <= maxJ; j ++ {
            col = append(col, grid[j + k - m][j])
        }

        if minJ > 0 {
            slices.Sort(col)
        } else {
            slices.SortFunc(col, func(a, b int) int { return b - a }) // 降序排列
        }

        for j := minJ; j <= maxJ; j ++ {
            grid[j + k - m][j] = col[j - minJ]
        }
    }

    return grid
}
相关推荐
优秘智能UMI4 小时前
UMI企业智脑智能营销:多平台视频矩阵引领营销新潮流
大数据·运维·人工智能·ai·矩阵·aigc
智者知已应修善业4 小时前
【C++无数组矩阵对角线平均值保留2位小数】2022-11-18
c语言·c++·经验分享·笔记·算法·矩阵
MoRanzhi12038 小时前
12. NumPy 数据分析与图像处理入门
大数据·图像处理·人工智能·python·矩阵·数据分析·numpy
贝塔实验室1 天前
ADMM 算法的基本概念
算法·数学建模·设计模式·矩阵·动态规划·软件构建·傅立叶分析
小麦矩阵系统永久免费2 天前
自动化运营|矩阵系统省心高效
运维·矩阵·自动化
MoRanzhi12032 天前
9. NumPy 线性代数:矩阵运算与科学计算基础
人工智能·python·线性代数·算法·机器学习·矩阵·numpy
疯狂的Alex2 天前
C++23特性全解析:从编译器支持矩阵到多维数组性能优化实战
rpc·矩阵·c++23
没书读了2 天前
考研复习-线性代数-第二章-矩阵
线性代数·考研·矩阵
源代码•宸2 天前
GAMES101:现代计算机图形学入门(Chapter2 向量与线性代数)迅猛式学线性代数学习笔记
经验分享·笔记·学习·线性代数·计算机图形学
wwlsm_zql2 天前
MITRE ATLAS对抗威胁矩阵:守护LLM安全的中国实践指南
人工智能·线性代数·安全·矩阵·大模型