Given numRows, generate the first numRows of Pascal's triangle.
For example, given numRows = 5,
Return
[ [1], [1,1], [1,2,1], [1,3,3,1], [1,4,6,4,1] ]
简单题,不过却有解法上还是有多种的。首先给出我简单直接的解法:
class Solution(object): def generate(self, numRows): """ :type numRows: int :rtype: List[List[int]] """ ret = [] for i in range(numRows): ret.append([1]) for j in range(1,i): ret[i].append(ret[i-1][j]+ret[i-1][j-1]) if i >0: ret[i].append(1) return ret
主要就是每行处理,将开始的1和最末端的1单独加上。时间复杂度为O(n^2),在结果上直接进行处理,不需要额外空间。