给定一个非负整数 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)
本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们。
反应式设计模式
Roland Kuhn、Brian Hanafee、Jamie Allen / 何品、邱嘉和、王石冲、林炜翔审校 / 清华大学出版社 / 2019-1-1 / 98.00 元
《反应式设计模式》介绍反应式应用程序设计的原则、模式和经典实践,讲述如何用断路器模式将运行缓慢的组件与其他组件隔开、如何用事务序列(Saga)模式实现多阶段事务以及如何通过分片模式来划分数据集,分析如何保持源代码的可读性以及系统的可测试性(即使在存在许多潜在交互和失败点的情况下)。 主要内容 ? “反应式宣言”指南 ? 流量控制、有界一致性、容错等模式 ? 得之不易的关于“什么行不通”的经验 ? ......一起来看看 《反应式设计模式》 这本书的介绍吧!