566.重置矩阵

题目描述

在这里插入图片描述

分析

矩阵映射

先将m*n的矩阵映射为一维数组,再将其映射为r*c的二维矩阵。

其中二维映射为一维的公式如下
x = i ∗ n + j x = i*n+j x=in+j
而一维映射为二维的公式如下
{ i = x / n j = x % n \left\{ \begin{aligned} i = x/n \\ \\ j = x\%n \end{aligned} \right. i=x/nj=x%n
而由二维直接映射为二维的公式如下
b e f o r e [ x / c ] [ x % c ] = a f t e r [ x / n ] [ x % c ] before[x/c][x\%c] = after[x/n][x\%c] before[x/c][x%c]=after[x/n][x%c]

代码

/**
 * 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, n = matColSize[0];
    if (m * n != r * c)
    {
        *returnSize = matSize;
        *returnColumnSizes = matColSize;
        return mat;
    }
    *returnSize = r;
    *returnColumnSizes = malloc(sizeof(int) * r);
    int **ret = malloc(sizeof(int *) * r);
    for (int i = 0; i < r; i++)
    {
        (*returnColumnSizes)[i] = c;
        ret[i] = malloc(sizeof(int) * c);
    }
    for (int x = 0; x < m * n; x++)
    {
        ret[x / c][x % c] = mat[x / n][x % n];
    }
    return ret;
}

收获

矩阵映射

掌握矩阵二维下标和一维序数之间的转换。可以理解并记忆公式

二级指针

指向一级指针变量的指针是二级指针。

一般可用于,像函数传递指针,可用指向这个指针的指针;二维数组的储存,也可采用二级指针。

二级指针

指向一级指针变量的指针是二级指针。

一般可用于,像函数传递指针,可用指向这个指针的指针;二维数组的储存,也可采用二级指针。

但需要注意二级指针相关malloc的使用。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值