您的位置:首页 > 游戏 > 手游 > 800元建网站_搜索引擎网址_什么软件可以推广自己的产品_网络营销课程ppt

800元建网站_搜索引擎网址_什么软件可以推广自己的产品_网络营销课程ppt

2024/12/24 22:03:20 来源:https://blog.csdn.net/kkksij/article/details/142406456  浏览:    关键词:800元建网站_搜索引擎网址_什么软件可以推广自己的产品_网络营销课程ppt
800元建网站_搜索引擎网址_什么软件可以推广自己的产品_网络营销课程ppt

给定一个非负整数 numRows生成「杨辉三角」的前 numRows 行。

在「杨辉三角」中,每个数是它左上方和右上方的数的和。

如何实现呢?

思路:首先,我们可以将杨辉三角视作i行j列的二维数组。除了第一行和第二行之外,其他行的元素都是首尾元素为1且该行的其他元素都是上一行相邻元素之和。有了这个思路,下面的实现步骤就可以有效的进行了。

步骤:

1.创建一个二维列表ret,用来存储每一行的元素。

2.创建一个只有元素1的列表(作为第一行)并将其添加到数组ret中

3.生成后续行:

(1):从第二行开始,通过for循环求该行的每一个元素,直到最后一行:

       for (int i = 1; i < numRows; i++)

(2):通过创建整形列表curRow,创建当前行的列表,同时通过add函数添加该行的第一个元素1。

(3):创建一个整形列表preRow用来接收上一行的值。

4.创建当前行中间的值:

(1):从第二个元素for循环到当前倒数第二个元素。for (int j = 1; j < i; j++) (因为第一个元素和倒数第二个元素都是1.)

(2):设置两个整形int val1 和 int val2,获取上一行相邻的两个元素( int val1=preRow.get(j); 

         和 int val2 = preRow.get(j-1);) 

(3):将两个值相加后添加到当前行:curRow.add(val1 + val2);

5.添加当前行的最后一个元素1:curRow.add(1)

6.将当前行添加到二维列表ret中。(ret.add(curRow);)

7.返回结果:return ret ,返回生成的杨辉三角。

具体实现代码如下:

class Solution {public List<List<Integer>> generate(int numRows) {List <List<Integer>> ret = new ArrayList<>(); //创建一个二维列表List<Integer> list0 = new ArrayList<>(); // 创建杨辉三角的第一行list0.add(1); //添加杨辉三角的第一个元素ret.add(list0); //将list0添加到ret中//从第二行开始求每个元素for(int i=1;i<numRows;i++){//处理第一个元素List<Integer> curRow = new ArrayList<>();curRow.add(1);//中间List<Integer> preRow = ret.get(i-1); //获取上一行的数组for(int j = 1;j<i;j++){int val1 = preRow.get(j);int val2 = preRow.get(j-1);curRow.add(val1+val2);}//尾巴处添加curRow.add(1);ret.add(curRow);}return ret;}
}

今天的分享就到这,喜欢的老铁来个三连吧

版权声明:

本网仅为发布的内容提供存储空间,不对发表、转载的内容提供任何形式的保证。凡本网注明“来源:XXX网络”的作品,均转载自其它媒体,著作权归作者所有,商业转载请联系作者获得授权,非商业转载请注明出处。

我们尊重并感谢每一位作者,均已注明文章来源和作者。如因作品内容、版权或其它问题,请及时与我们联系,联系邮箱:809451989@qq.com,投稿邮箱:809451989@qq.com