当前位置: 首页 > news >正文

【LeetCode】探索杨辉三角模型

在这里插入图片描述

一、题目描述

力扣原题

在这里插入图片描述

  • 首先我们要来了解一下题目本身在说些什么,通过下方的动图我们可以更加清楚地看到杨辉三角是怎样一步步生成的。给到的示例中我们通过输入杨辉三角的行数,然后通过计算得到这个杨辉三角的每一行是什么具体的数值

在这里插入图片描述

二、模型选择

首先我们要做的第一件事就是去选择正确的求解模型

  • 首先第一点,我们要来对比一下使用C语言求解和C++求解有什么不同,以下是题目已经给出的函数接口

在这里插入图片描述

  • 如果读者有学习过 C语言的指针 和 C++的引用 的话就可以知道,C++的祖师爷为什么要发明出引用这个东西,目的就是为了脱离C语言中非常繁杂的指针

我可以试着来分析一下如何使用C语言来进行求解,首先我们来看到的是这个 返回值int**

  • 为什么要返回int**呢,原因就在于对于我们这个杨辉三角来说,虽然呈现的是一个三角形的样子,但是呢其底层的实现其实还是一个二维数组,所以在函数内部我们肯定要去开辟出一个二维数组,读者可以通过下面这张图再来回顾一下有关二级指针的知识点(忘记了可以去看看指针相关文章)

在这里插入图片描述

  • 看完了返回值后,我们再来看看另外的两个参数,第一个是这个returnSize,其代表的是整个二维矩阵的行数,而returnColumnSizes代表的则是每一行的列数。
  • 但为何它们的类型一个是一级指针int*,另一个则是二级指针int**呢?如果你有看过 二叉树练习题之二叉树的遍历 的话就可以知道它们都叫做输出型参数

在这里插入图片描述

  • 在讲解 函数栈帧 的时候我们说到过这个函数的形参是实参的一份临时拷贝,内部形参的改动是不会影响实参的,所以我们在做二叉树题目的时候如果对这个参数没有做特殊处理的话在不同的递归层中就会出现 覆盖问题
  • 所以我们若是想让形参内部的变化带动外部一起修改的话,就需要外部传递变量的地址进来,那对于地址而言就需要使用 指针 来进行接收,一级指针的地址就需要二级指针来接收

所以就这么来看,我们若是使用C语言来求解本题的话,就会变得很麻烦

  • 那这个时候就可以使用我们心爱的C++了💖
class Solution {
public:vector<vector<int>> generate(int numRows) {}
};
  • 在C++中呢,我们一般不会使用指针来模拟二维数组,而是会采取vector<vector<int>>来进行表示

三、思路分析 + 代码详解

接下去我们就来分析一下这道题的思路🔍

  • 还记得下面这个动图吗,仔细观察我们可以发现每一行的第一个和最后一个数字都是1。而且中间空缺处的方块都是其 左上方的数字 + 右上方的数字

在这里插入图片描述

  • 具体地可以看以下的图示

在这里插入图片描述
【思路简述】:说一下我是如何去求解这道题的

  • 首先的话我们肯定需要先去定义出一个有关vector的二维矩阵
vector<vector<int>> vv;
  • 接下去呢便要为这个二维矩阵开辟出合适的大小来容纳,这里便可以使用到我们在vector中所学习的【resize】接口,既改变了size,又改变了capacity
vv.resize(numRows);
  • 因为矩阵中的每一行的第一个元素和最后一个元素都是1,所以我先去遍历这个矩阵,将所有的值设置为0,接下去呢再固定地将每一行的第一个元素vv[i][0]和最后一个元素vv[i][i]都设置为1
for(size_t i = 0;i < vv.size(); ++i)
{// 首先将二维数组中的所有元素初始化为0vv[i].resize(i + 1, 0);// 然后将每一行的第一个和最后一个元素初始化为1vv[i][0] = vv[i][i] = 1;
}
  • 接下去呢,就要去计算每一行的具体数值了,通过两层for循环去遍历这个二维矩阵,接下去呢我们只对数值为0的位置进行修改,因为每行的第一列和最后一列已经为1了,所以我们去修改的只是中间的那一部分
for(size_t i = 0;i < vv.size(); ++i)
{for(size_t j = 0;j < vv[i].size(); ++j){if(vv[i][j] == 0){// 右上方:vv[i - 1][j]// 左上方:vv[i - 1][j - 1]vv[i][j] = vv[i - 1][j] + vv[i - 1][j - 1];}}
}

对于当前的这个值就等于其上方的那一个数和上方左侧的那一个数之和

vv[i][j] = vv[i - 1][j] + vv[i - 1][j - 1];

整体代码展示:

class Solution {
public:vector<vector<int>> generate(int numRows) {vector<vector<int>> vv;vv.resize(numRows);for(size_t i = 0;i < vv.size(); ++i){// 首先将二维数组中的所有元素初始化为0vv[i].resize(i + 1, 0);// 然后将每一行的第一个和最后一个元素初始化为1vv[i][0] = vv[i][i] = 1;}for(size_t i = 0;i < vv.size(); ++i){for(size_t j = 0;j < vv[i].size(); ++j){if(vv[i][j] == 0){// 右上方:vv[i - 1][j]// 左上方:vv[i - 1][j - 1]vv[i][j] = vv[i - 1][j] + vv[i - 1][j - 1];}}}return vv;}
};

运行结果:

在这里插入图片描述

在这里插入图片描述

http://www.lryc.cn/news/106761.html

相关文章:

  • Qt 中引入ffmpeg 动态库
  • 工程师是怎样对待开源 qt
  • Maven中Servlet的坐标为什么要添加<scope>provided</scope>
  • 联发科CEO:未获准向华为供货,换机潮已过去,手机需求不会更差
  • 2023年DevOps和云趋势报告!
  • 怎么学习CSS相关技术知识? - 易智编译EaseEditing
  • Qt 2. QSerialPortInfo显示串口信息
  • linux or mac 查看进程的pid和占有的端口
  • 8.2Jmeter5.1:察看结果树的响应结果乱码
  • vscode 快捷键
  • Python pillow扩展库图像编程
  • 【Antv G6】导出图片
  • shared_ptr
  • ChatGPT + Stable Diffusion + 百度AI + MoviePy 实现文字生成视频,小说转视频,自媒体神器!(二)
  • git提交的时候Changes not staged for commit
  • 03_使用execle表生成甘特图
  • linux基础命令-ls
  • Chrome浏览器中的vue插件devtools的下载方式(使用Chrome应用商店/科学上网情况下)
  • 7、Kubernetes核心技术 - Secret
  • MATLAB算法实战应用案例精讲-【自动驾驶】路径规划(补充篇)
  • 农业与太阳能的互利共生
  • 每日一题(822. 翻转卡片游戏)-集合set
  • windows服务器iis PHP套件出现FastCGI等错误解决方法汇总
  • Qt Creator 11 开放源码集成开发环境新增集成终端和 GitHub Copilot 支持
  • Collections工具类(java)
  • C++ 第六弹 STL
  • 蓝桥杯上岸每日N题 第四期(最少刷题数)!!!
  • STM32 LWIP UDP 一对一 一对多发送
  • 【有趣的设计模式】23 种设计模式详解和场景分析
  • 【数据结构与算法】TypeScript 实现图结构