【LeetCode】Pascal's Triangle & II 解题报告

杨辉三角,分别求前n行和第n行。

【求杨辉三角前n行】

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]
]
基础题,直接看代码,注意边界。

public class Solution {
    public List> generate1(int numRows) {
        List> ret = new ArrayList>();
        
        if (numRows == 0) return ret;
        
        List list0 = new ArrayList(); 
        list0.add(1);
        ret.add(list0);
        
        for (int i = 2; i <= numRows; i++) {
            List list = new ArrayList(); 
            list.add(1);
            
            List pre = ret.get(ret.size()-1);
            for (int j = 1; j < i-1; j++) {
                list.add(pre.get(j-1) + pre.get(j));
            }
            
            list.add(1);
            ret.add(list);
        }
        
        return ret;
    }
    
    // another style
    public List> generate(int numRows) {
        List> ret = new ArrayList>();
        
        for (int i = 0; i < numRows; i++) {
            List list = new ArrayList(); 
            
            if (i == 0) {
                list.add(1);
            } else {
                List pre = ret.get(ret.size()-1);
                for (int j = 0; j <= i; j++) {
                    if (j == 0 || j == i) {
                        list.add(1);
                    } else {
                        list.add(pre.get(j-1) + pre.get(j));
                    }
                }
            }
            
            ret.add(list);
        }
        
        return ret;
    }
}

【求杨辉三角第n行】

Given an index k, return the kth row of the Pascal's triangle.

For example, given k = 3,
Return [1,3,3,1].

Note:
Could you optimize your algorithm to use only O(k) extra space?

注意 [1] 算第0行,[1, 1] 为第1行……

用O(k)的空间记录前一行就行了。

public class Solution {
    public List getRow(int rowIndex) {
        List list = new ArrayList();
        list.add(1);
        
        List pre = new ArrayList(list);
        for (int i = 1; i <= rowIndex; i++) { 
        	list.clear();
            list.add(1);
        	for (int j = 1; j < pre.size(); j++) {
                list.add(pre.get(j) + pre.get(j-1));
            }
            list.add(1);
            pre.clear();
            pre.addAll(list);
        }
        
        return list;
    }
}


你可能感兴趣的:(算法研究,LeetCode解题报告)