118. Pascal's triangle out of range

本文介绍了一种用于生成帕斯卡三角形的算法,该算法通过迭代方式逐行构建三角形,每行的元素由上一行的相邻元素相加得到。提供了详细的Python代码实现,并修正了原始代码中的一些错误。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

Given a non-negative integer numRows, generate the first numRows of Pascal's triangle.


In Pascal's triangle, each number is the sum of the two numbers directly above it.

Example:

Input: 5
Output:
[
     [1],
    [1,1],
   [1,2,1],
  [1,3,3,1],
 [1,4,6,4,1]
]

 

class Solution:
    def generate(self, numRows):
        """
        :type numRows: int
        :rtype: List[List[int]]
        """
        triangle=[]
        row=[]
        for rowid in range(numRows):
            row[0]=1   <=====out of range
            if rowid > 1:
                row[0],row[-1]=1,1
                for i in range(1, len(row)-1):
                    row[i]=triangle[[rowid-1][i-1]]+triangle[[rowid-1][i]]
                triangle.append(row)
        return triangle
            
        

 

 

调整如下:

class Solution:
    def generate(self, numRows):
        """
        :type numRows: int
        :rtype: List[List[int]]
        """
        triangle=[]
        for rowid in range(numRows):
            row=[None for _ in range(rowid+1)]  
            row[0],row[-1]=1,1
            for i in range(1,len(row)-1):
                row[i]=triangle[rowid-1][i-1]+triangle[rowid-1][i]
            triangle.append(row)
        return triangle
            
        

Note:

range()函数和for-in循环

函数原型:range(start, end, scan):

参数含义:start:计数从start开始。默认是从0开始。例如range(5)等价于range(0, 5);

                  end:技术到end结束,但不包括end 。例如:range(0, 5) 是[0, 1, 2, 3, 4]没有5

                  scan:每次跳跃的间距,默认为1。例如:range(0, 5) 等价于 range(0, 5, 1)

https://www.cnblogs.com/gongxr/p/7223652.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值