LeetCode 热题 100_杨辉三角(82_118_简单_C++)(动态规划)

LeetCode 热题 100_杨辉三角(82_118)

题目描述:

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

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

输入输出样例:

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

示例 2:
输入 : numRows = 1
输出: [[1]]

提示:

1 <= numRows <= 30

题解:

解题思路:

思路一(动态规划):

1、我们可以将数据使其左对齐,则第一列和对角线上的元素为1。其余位置为左上方元素+正上方元素。

2、具体思路如下:

① 可以使用二维动态数组来存储答案,第一行含有一个元素,第二行含有2个元素,以此类推。

② 可以将每行的元素初始值赋值为1,每行左右两端的初始值1不变,中间的元素由左上方元素+正上方元素得出。

2、复杂度分析:

① 时间复杂度:numRows2,生成「杨辉三角」的前 numRows 行。

② 空间复杂度:O(1)。不考虑返回值的空间占用。

代码实现

代码实现(思路一(动态规划)):
cpp 复制代码
class Solution {
public:
    // generate 函数用来生成杨辉三角的前 numRows 行
    vector<vector<int>> generate(int numRows) {
        // 创建一个二维数组 ans,大小为 numRows,每行的大小根据需要动态调整
        vector<vector<int>> ans(numRows);
        
        // 遍历每一行(从 0 到 numRows - 1)
        for (int i = 0; i < numRows; i++){
            // 为当前行调整大小,并初始化为全1
            // 每行的元素个数是 i+1,所以这行的元素数量为 i+1
            ans[i].resize(i+1, 1);
            
            // 从第二行开始,计算每一行中非边界的元素值
            // 这些元素的值等于上一行的左右两个元素之和
            for (int j = 1; j < i; j++){
                ans[i][j] = ans[i-1][j-1] + ans[i-1][j];
            }
        }
        
        // 返回最终生成的杨辉三角
        return ans;
    }
};
以思路一为例进行调试
cpp 复制代码
#include<iostream>
#include<vector>
using namespace std;

class Solution {
public:
    // generate 函数用来生成杨辉三角的前 numRows 行
    vector<vector<int>> generate(int numRows) {
        // 创建一个二维数组 ans,大小为 numRows,每行的大小根据需要动态调整
        vector<vector<int>> ans(numRows);
        
        // 遍历每一行(从 0 到 numRows - 1)
        for (int i = 0; i < numRows; i++){
            // 为当前行调整大小,并初始化为全1
            // 每行的元素个数是 i+1,所以这行的元素数量为 i+1
            ans[i].resize(i+1, 1);
            
            // 从第二行开始,计算每一行中非边界的元素值
            // 这些元素的值等于上一行的左右两个元素之和
            for (int j = 1; j < i; j++){
                ans[i][j] = ans[i-1][j-1] + ans[i-1][j];
            }
        }
        
        // 返回最终生成的杨辉三角
        return ans;
    }
};

int main(){
    int n=10;
    Solution s;
    vector<vector<int>> ans= s.generate(n);
    for(const auto &row:ans){
        for(const auto &i:row){
            cout<<i<<" ";
        }
        cout<<endl;

    }
    return 0;
}

LeetCode 热题 100_杨辉三角(82_118)原题链接

欢迎大家和我沟通交流(✿◠‿◠)

相关推荐
郭涤生6 小时前
布隆过滤器
c++
智者知已应修善业7 小时前
【求中位数】2024-1-23
c语言·c++·经验分享·笔记·算法
9ilk7 小时前
【C++】--- 特殊类设计
开发语言·c++·后端
地平线开发者7 小时前
PTQ 量化数值范围与优化
算法·自动驾驶
sali-tec7 小时前
C# 基于halcon的视觉工作流-章68 深度学习-对象检测
开发语言·算法·计算机视觉·重构·c#
测试人社区-小明8 小时前
智能弹性伸缩算法在测试环境中的实践与验证
人工智能·测试工具·算法·机器学习·金融·机器人·量子计算
罗西的思考8 小时前
【Agent】MemOS 源码笔记---(5)---记忆分类
人工智能·深度学习·算法
程序员zgh10 小时前
Linux系统常用命令集合
linux·运维·服务器·c语言·开发语言·c++
獭.獭.11 小时前
C++ -- STL【unordered_set与unordered_map的实现】
开发语言·c++·unordered_map·unordered_set
qq_4335545411 小时前
C++数位DP
c++·算法·图论