学习笔记(4月17日)vector底层原理

ops/2024/10/18 9:20:45/

1.vector<vector>底层原理

vector是表示可变大小数组的序列容器,相当于一个动态的数组,比数组优越的在于它具有可动态改变的大小,同时,它写成了类模板,说明可以适用于其他类型,包括vector本身,它的底层原理是这样实现的:

在vector里创建vector数组,相当于vector里存的是每一个vector数组的头指针,就像二维数组一样,

以顺序表为例,描述顺序表的结构体里有数组的头指针,元素个数、数组容量,那vector<vector>的结构体里就有指向第一个vector的头指针、元素个数、数组容量,而第一个vector里就有数组的头指针,元素个数、数组容量,类似于一种层层嵌套的感觉。

但实际上,标准的vector是由三个迭代器实现的,并非我们上面描述的那样。

例题:杨辉三角

题目链接

在C语言里可以用二维数组进行实现,但C++方式又该如何做呢?

用我们上面说的vector<vector>就行了。

这里的核心问题是:如何去分配空间?像C语言那样静态数组的一口气开完会浪费,开少又不够,vector里的resize可以完美的解决这个问题。

如上图的三角形,第一行有一个,第二行有两个,以此类推,所以,对每一个vector,我们含顺序进行resize,在这里reserve也可以起到开空间的作用,但resize还可以进行初始化,节省很多不必要的操作。

开辟空间完成后,根据杨辉三角的定义,每个数是它左上方和右上方的数的和,进行计算即可。

class Solution {
public:vector<vector<int>> generate(int numRows) {vector<vector<int>> vv(numRows);for(int i=0;i<numRows;i++){vv[i].resize(i+1,1);}for(int i=2;i<numRows;i++){for(int j=1;j<i;j++){vv[i][j]=vv[i-1][j-1]+vv[i-1][j];}}return vv;}
};

 


http://www.ppmy.cn/ops/6530.html

相关文章

npm 重要知识

1. npm config ls -l 此命令可以查看npm当前所有配置信息 2. .npmrc是npm重要的配置文件 位置在&#xff1a;C:\Users\{用户名} , 如下图 参考下文链接&#xff1a; https://www.cnblogs.com/zhuoss/p/17830408.html

java绘图在ubuntu报错

把JRT网站部署到ubuntu桌面系统上&#xff0c;开始没测试绘图部分功能&#xff0c;只试了连PostGreSql部分正常。后面试了生成位图部分发现报错。 报下面错误&#xff1a; (ColorModel.java:220)\n\tat java.desktop/java.awt.image.BufferedImage.(BufferedImage.java:286)\n…

[极客大挑战 2019]PHP

buuctf——[极客大挑战 2019]PHP 1.信息收集获取源代码/www.zip 2.放在phpstudy进行调试&#xff0c;直接输入任意select的值index是没有回显的&#xff0c;直接代码审计 通过index.php可以看到我们输入的参数select的值通过反序列化传入到了class.php 3.通过class.php我们可…

java.lang.OutOfMemoryError: WrappedJavaFileObject --idea启动项目内存溢出解决

java.lang.OutOfMemoryError 解决方案 现象 项目开发时&#xff0c;启动idea&#xff0c;报内存溢出错误&#xff0c;如下&#xff1a; java: java.lang.OutOfMemoryError: WrappedJavaFileObject.....解决 通过 调整idea 的 配置参数 来调整 jvm 大小解决。 -Xmx8192m-Xm…

2024年阿里云4核8G配置云服务器价格低性能高!

阿里云4核8G服务器租用优惠价格700元1年&#xff0c;配置为ECS通用算力型u1实例&#xff08;ecs.u1-c1m2.xlarge&#xff09;4核8G配置、1M到3M带宽可选、ESSD Entry系统盘20G到40G可选&#xff0c;CPU采用Intel(R) Xeon(R) Platinum处理器&#xff0c;阿里云优惠 aliyunfuwuqi…

Python基础:【练手小实验系列】个人财务管理系统

文章目录 题目功能解析参考代码题目 设计并实现一个简易的个人财务管理系统,功能如下: 1.收入记录:允许用户输入收入的金额和来源,记录当前总收入; 2.支出记录:允许用户输入支出的金额和用途,记录当前总支出; 3.财务汇总:显示目前的总收入、总支出和净余额; 4.条件查…

美团财务科技后端一面:如何保证数据一致性?延时双删第二次失败如何解决?

更多大厂面试内容可见 -> http://11come.cn 美团财务科技后端一面&#xff1a;项目内容拷打 美团财务科技后端一面&#xff1a;项目相关面试题&#xff0c;主要包含 Zset、延时双删失败重试、热点数据解决、ThreadLocal 这几个方面相关的内容 由于前几个问题是对个人项目的…

springboot日志使用 SLF4J+Logback 实现(springboot默认的日志实现),日志打印到控制台及日志输出到指定文件

还是直接上代码 Slf4j 这玩意 默认支持 不用引入 yml 配置文件 # 日志配置 如果配置了xml 这个就不生效了 xml优先级最高 #logging: # file: # path: /home/logs # 日志目录地址 # name: /home/logs/skeleton.log # max-size: 1KB # 设置日志大小的最大大小 1…