[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
}
相关推荐
多年小白19 小时前
AI 日报 - 2026年4月6日
网络·人工智能·科技·矩阵
笨笨饿1 天前
30_泰勒级数
c语言·stm32·嵌入式硬件·线性代数·机器学习·自动化·概率论
计算机安禾1 天前
【数据结构与算法】第28篇:平衡二叉树(AVL树)
开发语言·数据结构·数据库·线性代数·算法·矩阵·visual studio
郝学胜-神的一滴2 天前
[简化版 GAMES 101] 计算机图形学 03:线性代数下
开发语言·c++·线性代数·图形渲染
UltraLAB-F3 天前
科学计算与仿真算力瓶颈深度解析:从MATLAB矩阵分解到COMSOL/ANSYS稀疏求解,UltraLAB硬件方案如何破局?
开发语言·matlab·矩阵
AI科技星3 天前
全球AI信息场(信息网)基础理论与数学建模研究(乖乖数学)
开发语言·人工智能·线性代数·算法·机器学习·数学建模
⊱⋛赫宇⋚⊰3 天前
转专业数学
线性代数·机器学习·概率论
多年小白3 天前
2026年AI智能体“三国杀“:腾讯龙虾矩阵、阿里千问生态与字节豆包的技术架构全解析
网络·人工智能·科技·矩阵·notepad++
Brother Jiawei3 天前
概率-基础
线性代数·机器学习·概率论
米饭不加菜4 天前
机器人导论-通过逆矩阵公式证明齐次变换矩阵的逆
线性代数·矩阵·机器人