排序 + 模拟,LeetCode 1329. 将矩阵按对角线排序

一、题目

1、题目描述

矩阵对角线 是一条从矩阵最上面行或者最左侧列中的某个元素开始的对角线,沿右下方向一直到矩阵末尾的元素。例如,矩阵 mat 有 6 行 3 列,从 mat[2][0] 开始的 矩阵对角线 将会经过 mat[2][0]mat[3][1] 和 mat[4][2] 。

给你一个 m * n 的整数矩阵 mat ,请你将同一条 矩阵对角线 上的元素按升序排序后,返回排好序的矩阵。

2、接口描述

python3
class Solution:
    def diagonalSort(self, mat: List[List[int]]) -> List[List[int]]:
cpp
class Solution {
public:
    vector<vector<int>> diagonalSort(vector<vector<int>>& mat) {

    }
};

3、原题链接

1329. 将矩阵按对角线排序


二、解题报告

1、思路分析

遍历每一条对角线,放入临时数组排序完再放回去即可

2、复杂度

时间复杂度: O(mn log min(m, n)) 空间复杂度:O(min(m, n))

3、代码详解

python3
class Solution:
    def diagonalSort(self, mat: List[List[int]]) -> List[List[int]]:
        m, n = len(mat), len(mat[0])
        for i in range(m - 1, -1, -1):
            x, y = i, 0
            a = []
            while x < m and y < n:
                a.append(mat[x][y])
                x += 1
                y += 1
            x, y = i, 0
            for t in sorted(a):
                mat[x][y] = t
                x += 1
                y += 1
        for i in range(1, n):
            x, y = 0, i
            a = []
            while x < m and y < n:
                a.append(mat[x][y])
                x += 1
                y += 1
            x, y = 0, i
            for t in sorted(a):
                mat[x][y] = t
                x += 1
                y += 1

        return mat
cpp
class Solution {
public:
    vector<vector<int>> diagonalSort(vector<vector<int>>& mat) {
        int m = mat.size(), n = mat[0].size();
        for(int i = m - 1; ~i; i --){
            vector<int> a;
            for(int x = i, y = 0; x < m && y < n; x ++, y ++ )
                a.emplace_back(mat[x][y]);
            sort(a.begin(), a.end());
            for(int x = i, y = 0, t = 0; x < m && y < n; x ++, y ++, t ++)
                mat[x][y] = a[t];
        }
        for(int i = 1; i < n; i ++){
            vector<int> a;
            for(int x = 0, y = i; x < m && y < n; x ++, y ++ )
                a.emplace_back(mat[x][y]);
            sort(a.begin(), a.end());
            for(int x = 0, y = i, t = 0; x < m && y < n; x ++, y ++, t ++)
                mat[x][y] = a[t];
        }
        return mat;
    }
};

相关推荐

  1. 排序 + 模拟LeetCode 1329. 矩阵对角线排序

    2024-04-30 09:02:02       38 阅读
  2. leetcode1329--矩阵对角线排序

    2024-04-30 09:02:02       37 阅读
  3. 1329. 矩阵对角线排序

    2024-04-30 09:02:02       40 阅读
  4. 2024.4.29力扣每日一题——矩阵对角线排序

    2024-04-30 09:02:02       31 阅读
  5. leetcode2418.身高排序

    2024-04-30 09:02:02       34 阅读
  6. (55)身高排序

    2024-04-30 09:02:02       41 阅读

最近更新

  1. docker php8.1+nginx base 镜像 dockerfile 配置

    2024-04-30 09:02:02       94 阅读
  2. Could not load dynamic library ‘cudart64_100.dll‘

    2024-04-30 09:02:02       100 阅读
  3. 在Django里面运行非项目文件

    2024-04-30 09:02:02       82 阅读
  4. Python语言-面向对象

    2024-04-30 09:02:02       91 阅读

热门阅读

  1. 【MySQL】如何在MySQL中编写循环

    2024-04-30 09:02:02       30 阅读
  2. 如何贡献开源项目:Git 入门指南

    2024-04-30 09:02:02       29 阅读
  3. llm-universe学习小记录6--开源RAG项目学习

    2024-04-30 09:02:02       32 阅读
  4. LXC的原理及应用详解(三)

    2024-04-30 09:02:02       29 阅读