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

企业网站排名软件度智能优化google官网入口下载

企业网站排名软件度智能优化,google官网入口下载,网络服务主要包括,做电影字幕的网站一、题目描述 力扣原题 首先我们要来了解一下题目本身在说些什么,通过下方的动图我们可以更加清楚地看到杨辉三角是怎样一步步生成的。给到的示例中我们通过输入杨辉三角的行数,然后通过计算得到这个杨辉三角的每一行是什么具体的数值 二、模型选择 首先…

在这里插入图片描述

一、题目描述

力扣原题

在这里插入图片描述

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

在这里插入图片描述

二、模型选择

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

  • 首先第一点,我们要来对比一下使用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.yayakq.cn/news/587852/

相关文章:

  • 做微网站是订阅号还是服务号号怎么做网站关键词
  • 国内网站欣赏国外好的设计网站有哪些
  • 做微商代理去哪个网站西安知名网络推广公司
  • 开发公众号 微网站开发wordpress免费模板怎么使用
  • 家居网站建设哪家好免费网站seo诊断
  • 商城站到商城汽车站淘宝客不做网站可以做么
  • 用pycharm做网站觅知网免费素材图库
  • 全网展示型网站建设dw如何制作表格网页
  • 网站域名注册证书是什么asp企业建站系统
  • 网站页头设计门户网站做等级保护测评
  • 水产公司网站源码成都网站开发建设公司
  • 备案 网站名字本机建的网站打开却很慢
  • 什么能建我的网站呢外贸seo优化
  • 一起做网站女装夏季裙开发app费用
  • 安康市建设局网站企业网站建设分工
  • 中国建设网站首页邯郸招聘信息网
  • 惠州网站建设推广威县做网站哪家好
  • 动物做logo的网站给公司做网站 图片倾权
  • 成都网站建设爱特通网店代运营合同模板
  • 广东免费建站公司公关团队
  • 做微信公众平台的网站网站流量突然增大
  • 网站搜索建设it外包公司是做什么的
  • 2021手机能看的网站西安未央区今天出啥事了
  • 网站建设视频教程免费下载对于网站建设的体会
  • 杭州设计公司招聘福州seo按天收费
  • 做沙盘实训在哪个网站做邯郸做wap网站找谁
  • 网站开发毕业设计代做网站开发总结标题
  • 关键词挖掘站网重庆 建网站
  • 南昌网站建设哪家好wordpress 软件价格
  • 怎么做网站动态框杭州百度推广