[leetcode in golang]119、杨辉三角 II

aside section ._1OhGeD · · 994 次点击 · · 开始浏览    
这是一个创建于 的文章,其中的信息可能已经有所发展或是发生改变。

杨辉三角II 不需要输出全部数字,只需要输出最后一行。
最后一行由前一行计算得,同一行也有计算方法:
[1,3,3,1]
下一行:
在前一行数组下标为0的位置插入0,而后new[i]=old[i]+old[i+1]
[(0)+1,1+3,3+3,3+1,1]
[1,4,6,4,1]

func getRow(rowIndex int) []int {
    res:=make([]int,rowIndex+1)
    for t:=range res{
        res[t]=0
    }
   res[0]=1
    for i:=1;i<rowIndex+1;i++{
        for j:=i;j>=1;j--{
            res[j]=res[j-1]+res[j]
        }
    }
    return res
}

注意输入0或1:

特殊情况也可以单独考虑,不单独考虑就要注意逻辑。res[0]=1要放在for循环之外。

数组初始化遇到问题:non-constant array bound:

You can't instantiate an array like that with a value calculated at runtime. Instead use make to initialize a slice with the desired length. It would look like this;

left := make([]int, leftLength)

有第二种解法:数学组合公式。


有疑问加站长微信联系(非本文作者)

本文来自:简书

感谢作者:aside section ._1OhGeD

查看原文:[leetcode in golang]119、杨辉三角 II

入群交流(和以上内容无关):加入Go大咖交流群,或添加微信:liuxiaoyan-s 备注:入群;或加QQ群:692541889

994 次点击  
加入收藏 微博
暂无回复
添加一条新回复 (您需要 登录 后才能回复 没有账号 ?)
  • 请尽量让自己的回复能够对别人有帮助
  • 支持 Markdown 格式, **粗体**、~~删除线~~、`单行代码`
  • 支持 @ 本站用户;支持表情(输入 : 提示),见 Emoji cheat sheet
  • 图片支持拖拽、截图粘贴等方式上传