给定一个非负整数 numRows,生成杨辉三角的前 numRows 行。 复制代码
示例:
在杨辉三角中,每个数是它左上方和右上方的数的和。 复制代码
思考:
第一行为1,第二行开始,除了第一个和最后一个为1,其他的第i个等于迁移行的第i-1个加上前一行的第i个。 复制代码
实现:
class Solution { public List<List<Integer>> generate(int numRows) { List<List<Integer>> res = new ArrayList<>(); //0行直接返回 if (numRows == 0) { return res; } //加入第一行的1 res.add(new ArrayList<Integer>()); res.get(0).add(1); //从第二行开始 for (int count = 1; count < numRows; count++) { List<Integer> list = new ArrayList<>(); res.add(list); for (int inner = 0; inner <= count; inner++) { //第一个和最后一个为1 if (inner == 0 || inner == count) { list.add(1); } else {//其他的等于前一行的第(inner - 1)个元素与第inner个元素相加 list.add(res.get(count - 1).get(inner - 1) + res.get(count - 1).get(inner)); } } } return res; } }复制代码
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持 码农网
猜你喜欢:- C语言打印杨辉三角代码及解析
- leetcode # 118:Pascal's Triangle 杨辉三角
- LeetCode - 118 - 杨辉三角(pascals-triangle)
- LeetCode - 119 - 杨辉三角II(pascals-triangle-ii)
本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们。
算法分析导论
(美)Robert Sedgewick、(法)Philippe Flajolet / 冯舜玺、李学武、裴伟东、等其他 / 机械工业出版社 / 2006-4 / 38.00元
本书阐述了用于算法数学分析的主要方法,所涉及的材料来自经典数学课题,包括离散数学、初等实分析、组合数学,以及来自经典的计算机科学课题,包括算法和数据结构,本书内容集中覆盖基础、重要和有趣的算法,前面侧重数学,后面集中讨论算法分析的应用,重点的算法分的的数学方法。每章包含大量习题以及参考文献,使读者可以更深入地理解书中的内容。 本书适合作为高等院校数学、计算机科学以及相关专业的本科生和研究生的......一起来看看 《算法分析导论》 这本书的介绍吧!