vector容器解决杨辉三角

一、题目描述

118. 杨辉三角

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

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

vector容器解决杨辉三角_第1张图片

示例 1:

输入: numRows = 5
输出: [[1],[1,1],[1,2,1],[1,3,3,1],[1,4,6,4,1]]

示例 2:

输入: numRows = 1
输出: [[1]]

二、题目解析

在之前只学了C语言,用二维数组创建写这道题时,需要动态开辟数组。很麻烦。

但是学了vector容器之后,使用它来秒解这道题,非常的爽!!!

首先我们需要开辟空间,vector容器开辟空间的用resize这个方法,并且开辟的时候还能直接赋值,简直不要太爽!

(注意resize和reverse的区别:Reserve操作是用于预分配Vector的容量,Reserve操作只是预分配内存,并不会改变Vector的大小Resize操作是用于改变Vector的大小。当我们需要增加或减少Vector中的元素数量时,可以使用Resize操作。Resize会改变Vector的大小,并且如果需要的话,它会分配或释放内存。)

所以我们可以利用for循环,让第一行开辟的数据是1,第二行是2,以此来动态开辟数组!

杨辉三角最核心的一点就是:该元素的值 = 上一行同位置的元素 + 上一行同位置元素的前一个元素

最后直接返回vector数组即可~

三、原码

class Solution {
public:
    vector> generate(int numRows) {
        vector> vv;
        vv.resize(numRows);
        for(int i = 0;i

你可能感兴趣的:(C语言/C++练习题,leetcode,算法)