Leetcode566. 重塑矩阵

Every day a Leetcode

题目来源:566. 重塑矩阵

解法1:二维数组间的映射

请添加图片描述

如上图所示,一个m*n的矩阵,按行优先映射成一个一维数组。

矩阵中点(i,j)在一维数组的下标为:x=i*n+j。

然后,我们在把这个一维数组按行优先映射成一个r*c的矩阵。

一维数组的下标为x的点在矩阵中的坐标为:i=x/c,j=x%c。

据此得到关系:ans[x/c][x%c]=mat[x/n][x%n];

当然,我们首先要判断mn是否等于rc,若不等,说明不能重塑,返回原矩阵。

代码:

/**
 * Return an array of arrays of size *returnSize.
 * The sizes of the arrays are returned as *returnColumnSizes array.
 * Note: Both returned array and *columnSizes array must be malloced, assume caller calls free().
 */
int** matrixReshape(int** mat, int matSize, int* matColSize, int r, int c, int* returnSize, int** returnColumnSizes){
    int m=matSize;
    int n=matColSize[0];
    if(m*n!=r*c)
    {
        *returnSize=matSize;
        *returnColumnSizes=matColSize;
        return mat;
    }
    *returnSize=r;
    *returnColumnSizes=malloc(r*sizeof(int));
    int **ans=malloc(r*sizeof(int*));
    for(int i=0;i<r;i++)
    {
        (*returnColumnSizes)[i]=c;
        ans[i]=malloc(c*sizeof(int));
    }

    for(int x=0;x<m*n;x++)
    {
        ans[x/c][x%c]=mat[x/n][x%n];
    }
    return ans;


}

结果:

在这里插入图片描述

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

UestcXiye

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值