博客
关于我
LeetCode119.杨辉三角2Golang版
阅读量:382 次
发布时间:2019-03-05

本文共 677 字,大约阅读时间需要 2 分钟。

要解决给定一个非负索引 k,返回杨辉三角的第 k 行的问题,我们可以利用杨辉三角的性质,即每一行的数是其左右邻居的和。通过动态计算组合数,我们可以直接生成每一行的数值。

方法思路

杨辉三角的每一行可以看作是组合数的序列。第 k 行的数是组合数 C(k, 0), C(k, 1), ..., C(k, k)。为了生成第 k 行,我们可以从左到右依次计算每个位置的值。具体来说,第 i 个数可以通过前一个数乘以 (k - i + 1) 再除以 i 来计算。

解决代码

func getRow(rowIndex int) []int {    yanghui := make([]int, rowIndex + 1)    yanghui[0] = 1    for i := 1; i <= rowIndex; i++ {        yanghui[i] = yanghui[i-1] * (rowIndex - i + 1) / i    }    return yanghui}

代码解释

  • 初始化数组:创建一个长度为 rowIndex + 1 的数组 yanghui,并将第一个元素初始化为 1。
  • 计算每个位置的值:从 i=1 到 i=rowIndex,依次计算每个位置的值。使用公式 yanghui[i] = yanghui[i-1] * (rowIndex - i + 1) / i 来计算每个位置的值。
  • 返回结果:返回生成的杨辉三角第 k 行的数组。
  • 这种方法通过直接计算组合数,避免了传统杨辉三角生成方式中的复杂循环和覆盖问题,实现简洁高效。

    转载地址:http://nlcwz.baihongyu.com/

    你可能感兴趣的文章
    Openlayers Map事件基础及重点内容讲解
    查看>>
    Openlayers Overlay基础及重点内容讲解
    查看>>
    Openlayers Select的用法、属性、方法、事件介绍
    查看>>
    Openlayers Source基础及重点内容讲解
    查看>>
    Openlayers view三要素(zoom,center,projection)及其他参数属性方法介绍
    查看>>
    OpenLayers 入门使用
    查看>>
    Openlayers 入门教程(一):应该如何学习 Openlayers
    查看>>
    openlayers 入门教程(七):Interactions 篇
    查看>>
    openlayers 入门教程(三):view 篇
    查看>>
    openlayers 入门教程(九):overlay 篇
    查看>>
    openlayers 入门教程(二):map 篇
    查看>>
    openlayers 入门教程(五):sources 篇
    查看>>
    openlayers 入门教程(八):Geoms 篇
    查看>>
    openlayers 入门教程(六):controls 篇
    查看>>
    openlayers 入门教程(十一):Formats 篇
    查看>>
    openlayers 入门教程(十三):动画
    查看>>
    openlayers 入门教程(十二):定位与轨迹
    查看>>
    openlayers 入门教程(十五):与 canvas、echart,turf 等交互
    查看>>
    openlayers 入门教程(十四):第三方插件
    查看>>
    openlayers 入门教程(十):style 篇
    查看>>