zoukankan      html  css  js  c++  java
  • Pascal's Triangle(杨辉三角)

    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]
    ]

    思路:动态规划,前面的构建出来了,后面根据某种关系也就可以构建出来。

    这个要根据前一行来构建下一行。这里的for循环是直接遍历当前行的个数,往里面添加多少个。这里主要运用当前行的规律

     public List<List<Integer>> generate(int numRows) {
                List<List<Integer>> result=new ArrayList<List<Integer>>();
              if(numRows==0) return result;
              List<Integer> row,pre=null;//row代表当前行,pre代表前一行
              for(int i=1;i<=numRows;i++){//第几行,第几行就有几个元素
                  row=new ArrayList<>();
          /*这里for循环中的步骤很巧妙,遍历当前行,若为开头或结尾,加1,其他情况再从前一行中计算,这样一开始就不会从前一行计算,所以不会出问题。
            
          */
    for(int j=0;j<i;j++){//当前行的元素下标 if(j==0||j==i-1) row.add(1); else row.add(pre.get(j-1)+pre.get(j));//一开始第一行第二行这里不会执行, } pre=row; result.add(row); } return result; }

     还有一种更巧妙的,直接在一个list上操作。见代码。注意最后添加的时候new一个list,不然只能添加最终结果

    class Solution {
        public List<List<Integer>> generate(int numRows) {
            List<List<Integer>> res=new ArrayList<List<Integer>>();
            if(numRows==0) return res;
            List<Integer> list=new LinkedList<>();
            for(int i=1;i<=numRows;i++){
                list.add(1);
                for(int j=i-2;j>=1;j--){
                    list.set(j,list.get(j)+list.get(j-1));
                }
    //这里要新new一个list加进去,不然如果直接添加list,出现的情况是添加了最终结果(第一层for循环结束时的list)。
                res.add(new LinkedList<Integer>(list));
            }
            return res;
        }
    }
  • 相关阅读:
    实时控制软件设计-读书笔记
    1月9号
    第一组咖啡机器人部分图形设计
    《构建之法:现代软件工程》阅读笔记
    《实时控制软件设计》第三周作业
    实时控制软件设计第二次作业
    《实时控制软件设计》团队项目个人总结
    《实时控制软件设计》团队项目第三天工作日志
    《实时控制软件设计》团队项目第三天工作日志
    《实时控制软件设计》团队项目第二天工作日志
  • 原文地址:https://www.cnblogs.com/xiaolovewei/p/8080798.html
Copyright © 2011-2022 走看看