数据结构入门4-数组 『重塑矩阵 | 杨辉三角』


💪💪💪此系列仅为记录本人补充学习数据结构相关知识,有兴趣的,大家可以共同学习👏👏👏

[= 重塑矩阵 =]

题目描述

题目传送门

解题思路

1、判断是否满足重塑条件 原矩阵元素个数是否与重塑矩阵个数相同
2、不满足条件 直接返回原矩阵
3、满足条件:先构建初始化重塑矩阵
4、遍历原矩阵,并填充重塑矩阵

解题方法

func matrixReshape(mat [][]int, r int, c int) [][]int {
    //判断是否满足条件 m*n = r*c
    if len(mat)*len(mat[0]) != r*c {
        return mat
    }
    // 满足条件 构建重塑矩阵
    res := make([][]int, r)
    for i:=0;i<r;i++{
        res[i] = make([]int, c)
    }
    // 遍历原矩阵 填充新矩阵
    newR, newC := 0,0
    for i := 0;i<len(mat);i++{
        for j:=0;j<len(mat[0]);j++{
            res[newR][newC] = mat[i][j] 
            newC++
            // 满足列数,则换行,同时重置列值为0
            if newC == c {
                newR++
                newC=0
            } 
        }
    }
    return res
}

在这里插入图片描述

[= 杨辉三角 =]

题目描述

题目传送门

解题思路

纯数学的解法 刚开始连杨辉三角都不知道,头疼😱😱😱😱😱😱😱😱😱😱

解题方法

func generate(numRows int) [][]int {
    // 纯数学的东西,很头疼呀
    ans := make([][]int, numRows)
    for i := range ans {
        // 循环行
        ans[i] = make([]int, i+1)
        // 首尾都是1
        ans[i][0] =  1
        ans[i][i] = 1
        // 填充每行的中间列
        for j := 1;j<i;j++{
            ans[i][j] = ans[i-1][j-1] + ans[i-1][j]
        }
    }
    return ans
}

在这里插入图片描述

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

Bennett_G

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

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

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

打赏作者

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

抵扣说明:

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

余额充值