leetcode_566 重塑矩阵

283 阅读1分钟

要求

在 MATLAB 中,有一个非常有用的函数 reshape ,它可以将一个 m x n 矩阵重塑为另一个大小不同(r x c)的新矩阵,但保留其原始数据。

给你一个由二维数组 mat 表示的 m x n 矩阵,以及两个正整数 r 和 c ,分别表示想要的重构的矩阵的行数和列数。

重构后的矩阵需要将原始矩阵的所有元素以相同的 行遍历顺序 填充。

如果具有给定参数的 reshape 操作是可行且合理的,则输出新的重塑矩阵;否则,输出原始矩阵。

示例 1:

image.png

输入:mat = [[1,2],[3,4]], r = 1, c = 4
输出:[[1,2,3,4]]

示例 2:

image.png

输入:mat = [[1,2],[3,4]], r = 2, c = 4
输出:[[1,2],[3,4]]

核心代码

class Solution:
    def matrixReshape(self, mat: List[List[int]], r: int, c: int) -> List[List[int]]:
        m,n = len(mat),len(mat[0])
        if m * n != c * r:
            return mat
        l = list()
        for row in mat:
            for item in row:
                l.append(item)
   
        cnt = 0
        res = list()
        for i in range(r):
            temp = list()
            for j in range(c):
                temp.append(l[cnt])
                cnt += 1
            res.append(temp)
        return res

image.png

解题思路:我们将数组变成一个一行的数组,然后通过两层循环将行、列进行元素的重新分配,比较简单。