STL中vector动态二维数组理解(杨辉三角)

题目链接:118.杨辉三角

题目描述:

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

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


题目指要:

本题的主要目的是理解vector<vector<int>>,以及会访问vector<vector<int>>元素。

vector<vector<int>>实质是一个vector 里面的类型是vector<int>

template<class T>
class vector
{
private:T* _a;size_t _size;size_t _capacity;
};

构造一个vv动态二维数组,vv中总共有n个元素,每个元素都是vector类型的,每行没有包含任何元素,如果n为5时如下所示:

vv中元素填充完成之后,如下图所示:

访问某行某列的元素可以直接使用方括号,例如将第二行第五列元素置为0

vv[1][4] = 0;

可以这样访问的原因实质是底层运算符重载

vector<int>
class vector
{
public:int& operator[](size_t i){//....return _a[i];}
private:int* _a;size_t _size;size_t _capacity;
};//vector<vector<int>>
class vector
{
public:vector<int>& operator[](size_t i){//....return _a[i];}
private:vector<int>* _a;size_t _size;size_t _capacity;
};

问题解答:

本题比较简单,通过观察可以发现:

1️⃣每行第一列和最后一列数字为1

2️⃣除了每行第一列和最后一列,其余位置 = 上一行当前位置 + 上一行当前-1位置之和

因此我们可以初始化二维数组每个数为0,将每行第一列和最后一列数字置为1,将其余不是1的数字进行上一行当前位置 + 上一行当前-1位置相加

代码示例:

class Solution {
public:vector<vector<int>> generate(int numRows) {vector<vector<int>> vv;//开一个二维顺序表(数组)vvvv.resize(numRows);//开每行的空间//开每列的空间for(int i = 0 ;i < numRows ; i++){vv[i].resize(i+1,0);//数组中每个元素置为0vv[i][0] = vv[i][vv[i].size()-1] = 1;//让第一列和最后一列置为1}for(int i = 0 ;i < numRows ;i++){for(int j = 0 ;j < vv[i].size();j++){if(vv[i][j] == 0){vv[i][j] = vv[i-1][j-1] + vv[i-1][j];}}}return vv;}
};

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/846504.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

18 跨团队 没有汇报线的人和事就是推不动?

在“05 | 大项目&#xff1a;把握关键点&#xff0c;谋定而后动”和“11 | 勤沟通&#xff1a;在信任的基础上&#xff0c;让沟通简单”两讲中&#xff0c;我提过“跨团队”这件事&#xff0c;很多同学带团队之后&#xff0c;无法回避的一个问题就是“跨团队协作”&#xff0c;…

【Linux】System V 消息队列(不重要)

一、消息队列的原理 一个进程给另一个进程发送类型数据块的方式每一个数据快都被认为是有一个类型的&#xff0c;接收者进程接收的数据快可以有不同的类型值 二、消息队列的接口 和共享内存的接口很像&#xff1a; 消息队列的创建 创建消息队列我们需要用msgget函数&#x…

logging二次封装

import logging import os import time from logging.handlers import RotatingFileHandlerclass Logger():logs_dir os.path.dirname(os.path.dirname(os.path.abspath(__file__))) \\report\\logsdef __init__(self, name):self.logger logging.getLogger(name)#设置级别…

JavaScript函数进阶学习

文章目录 JavaScript函数进阶函数提升作用流程 函数参数动态参数剩余参数展开运算符 箭头函数基本语法箭头函数参数箭头函数的this 遍历数组的forEach方法语法 JavaScript函数进阶 函数提升 函数有时可以先调用再声明。 作用流程 函数提升的作用流程与变量提升类似&#xf…

移动端框架:加速移动应用开发与提升跨平台兼容性

在当今快速发展的移动应用领域&#xff0c;开发者们面临着如何快速构建、维护并发布跨平台应用的挑战。为了应对这一挑战&#xff0c;移动端框架应运而生&#xff0c;它们不仅加速了移动应用的开发流程&#xff0c;还提升了应用的跨平台兼容性&#xff0c;并确保了应用性能与原…

C++的算法:动态规划算法

动态规划(Dynamic Programming,简称DP)是一种在数学、计算机科学和经济学中使用的,通过把原问题分解为相对简单的子问题的方式来求解复杂问题的方法。动态规划常常适用于有重叠子问题和最优子结构性质的问题。 动态规划的基本步骤: 1. 描述问题的最优解的结构:确定问题的…

2024/6/2 英语每日一段

However, they denied Hirst had been deliberately misleading, arguing that it was his “usual practice” to date physical works in a conceptual art project with the date of the project’s conception, which in the case of The Currency was 2016. Hirst and Sci…

Python | 自动探索性数据分析(EDA)库SweetViz

SweetViz是一个开放源代码Python库&#xff0c;主要用于生成精美的高密度可视化文件&#xff0c;启动探索性数据分析&#xff08;EDA&#xff09;&#xff0c;输出为完全独立的HTML应用程序。 探索性数据分析&#xff08;EDA&#xff09;是分析和总结数据集主要特征的过程&…

uni-app(优医咨询)项目实战 - 第7天

学习目标&#xff1a; 能够基于 WebSocket 完成问诊全流程 能够使用 uniCloud 云存储上传文件 能够完成查看电子处方的功能 能够完成医生评价的功能 一、问诊室 以对话聊天的方式向医生介绍病情并获取诊断方案&#xff0c;聊天的内容支持文字和图片两种形式。 首先新建一…

AOP案例

黑马程序员JavaWeb开发教程 文章目录 一、案例1.1 案例1.2 步骤1.2.1 准备1.2.2 编码 一、案例 1.1 案例 将之前案例中增、删、改相关节后的操作日志记录到数据库表中。 操作日志&#xff1a;日志信息包含&#xff1a;操作人、操作时间、执行方法的全类名、执行方法名、方法…

网关(Gateway)- 内置过滤器工厂

官方文档:Spring Cloud Gateway 内置过滤器工厂 AddRequestHeaderGatewayFilterFactory 为请求添加Header Header的名称及值 配置说明 server:port: 8088 spring:application:name: api-gatewaycloud:nacos:discovery:server-addr: 127.0.0.1:8847username: nacospassword: …

Java中的垃圾回收机制详解

一、技术难点 Java中的垃圾回收机制&#xff08;Garbage Collection, GC&#xff09;是Java语言的一个核心特性&#xff0c;它负责自动管理堆内存中的对象&#xff0c;自动回收不再使用的对象占用的内存空间&#xff0c;从而避免了C/C等语言中常见的内存泄漏和野指针问题。然而…

52.WEB渗透测试-信息收集-CDN识别绕过(5)

免责声明&#xff1a;内容仅供学习参考&#xff0c;请合法利用知识&#xff0c;禁止进行违法犯罪活动&#xff01; 内容参考于&#xff1a; 易锦网校会员专享课 上一个内容&#xff1a;51.WEB渗透测试-信息收集-CDN识别绕过&#xff08;4&#xff09; 端口扫描其他内容参考&…

几何裁剪技术在AI去衣应用中的革新作用

引言&#xff1a; 随着人工智能技术的飞速发展&#xff0c;其在图像处理领域的应用也日益广泛。特别是在AI去衣技术中&#xff0c;几何裁剪技术扮演着至关重要的角色。本文将深入探讨几何裁剪技术在AI去衣中的应用及其带来的影响。 一、几何裁剪技术概述 几何裁剪技术是一种基…

容器技术的发展与影响

一、引言 容器技术近年来在软件开发和运维领域引起了广泛关注。本文将探讨容器技术的发展历程、其在技术领域的应用及其深远影响。 二、容器技术的发展历程 1.1 初期的容器技术 容器技术并非新概念&#xff0c;其历史可以追溯到Unix操作系统。早在20世纪70年代&#xff0c;…

【线性表】顺序存储和链式存储的实现

文章目录 顺序存储链式存储单向链表循环链表 线性表的定义 (1)概念定义&#xff1a;用数据元素的有限序列表示叫做线性表&#xff1b;线性表中数据元素的类型可以为简单类型&#xff0c;也可以为复杂类型。许多实际应用问题所涉的基本操作有很大相似性&#xff0c;不应为每个具…

DALL-2E是什么?它有什么功能和特性?它值不值得我们去学习?我们该如何去学习呢?

1.DALL-2E是什么&#xff1f; DALL-2E 是一个智能对话生成模型&#xff0c;其全称为Diverse All-round Language Generation for Effective Conversation。该模型是由微软研究院于2022年开发的&#xff0c;目的是为了提高对话生成系统在多样性和全面性方面的表现。 DALL-2E 基…

建模杂谈系列244 TimeTraveller

说明 所有的基于时间处理和运行的程序将以同样的节奏同步和执行 TT(TimeTraveller)是一个新的设计&#xff0c;它最初会服务与量化过程的大量任务管理&#xff1a;分散开发、协同运行。但是很显然&#xff0c;TT的功能将远不止于此&#xff0c;它将服务大量的&#xff0c;基于时…

【四大组件】-- 内容提供器 ContentProvider

目录 内容提供器 ContentProvider定义&#xff0c;是什么作用&#xff0c;为什么原理&#xff0c;机制使用方法统一资源标识符 URIMIMEUriMatcherContentUrisContentProviderContentResolver监听数据变化 总结面试问题 内容提供器 ContentProvider Android ContentProvider 基…

【spring】第二篇 bean实例化

对象已经能交给Spring的IOC容器来创建了&#xff0c;但是容器是如何来创建对象的呢? 就需要研究下bean的实例化过程&#xff0c;在这块内容中主要解决两部分内容&#xff0c;分别是 bean是如何创建的 实例化bean的三种方式&#xff0c;构造方法,静态工厂和实例工厂 在讲解这…