重 塑 矩 阵

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

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

输入:
nums =
[[1,2],
[3,4]]
r = 1, c = 4
输出:
[[1,2,3,4]]
解释:
行遍历nums的结果是 [1,2,3,4]。新的矩阵是 1 * 4 矩阵, 用之前的元素值一行一行填充新矩阵。

算法一

class Solution {

    /**
     * @param Integer[][] $mat
     * @param Integer $r
     * @param Integer $c
     * @return Integer[][]
     */
    function matrixReshape($mat, $r, $c) {
        $res = $_mat = [];
        foreach($mat as $arr){
            foreach($arr as $a){
                $_mat[] = $a;
            }
        }
            
        if(sizeof($_mat) != $r* $c){
            return $mat;
        }
        
        for($i = 0;$i<$r;$i++){
            for($j = 0;$j <$c;$j++){
                $res[$i][$j] = array_shift($_mat);
            }
        }
       
        return $res;
    }
}

算法二

class Solution {

    /**
     * @param Integer[][] $mat
     * @param Integer $r
     * @param Integer $c
     * @return Integer[][]
     */
    function matrixReshape($mat, $r, $c) {
        $result = [];
        $l = count($mat);
        $w = count($mat[0]);
        if($l*$w != $r*$c){
            return $mat;
        }

        for($i = 0;$i<$l*$w;$i++){
            $result[$i/$c][$i%$c] = $mat[$i/$w][$i%$w];
        }
        return $result;
    }
}

算法1:直接将数组整理成一位数组再一个个截取到二维数组。
算法2:根据一维数组和二维数组转换的规律,假设二维数组的行数为$l,列数为$w,一位数组的第$i个元素在二维数组的行标和列表分别为:$i/$w和$i%$w,根据此规律可以根据原始数组的个数一次完成矩阵的重塑。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

_earnest

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

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

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

打赏作者

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

抵扣说明:

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

余额充值