C++ Vector容器操作

news2024/11/15 13:36:58

vector赋值操作

提供三种方式进行赋值

        assign函数是STL中提供的一个成员函数,assign() 函数可以重新定义向量的内容,可以用于设置特定数量的重复元素,或者直接用另一个容器的元素来替换当前向量的元素。

//直接赋值,类似于拷贝
vector<int>v2;
v2 = v1;
//利用assign()函数
//begin()是闭区间,所在值可取到
//end()是开区间,所在值取不到
vector<int>v3;
v3.assign(v1.begin(),v1.end());
//n个elem方式赋值
vector<int>v4;
v4.assign(10, 100);

vector容器容量大小

判断容器是否为空:empty()

容器容量 :capacity()

返回容器中元素个数:size()

重新指定容器的长度:resize(int num)

重载resize (int num,elem),重新指定容器长度,若变成,则填充 elem,若重新指定的容器短。超出的部分将被删除。

示例代码+注释:

void test()
{
	//创建容器v1,往里面存放0~9
	vector<int>v1;
	for (int i = 0; i < 10; i++)
	{
		v1.push_back(i);
	}
	for (vector<int>::iterator it = v1.begin(); it != v1.end(); it++)
	{
		cout << *it << endl;
	}
	//判断容器是否为空!
	//若结果为真,代表容器为空
	if (v1.empty())
	{
		cout << "容器为空!" << endl;
	}
	else {
		cout << "容器不为空" << endl;
		//获取容器的容量
		cout << "容器的容量为:" << v1.capacity() << endl;
		//获取容器的大小
		cout << "容器的容量为:" << v1.size() << endl;
	}
	//重新指定容器大小
	//若重新指定的空间过长,默认用0填充
	v1.reserve(15);
	//若重新指定的空间比原来小,则超出的部分会被删除
}

vector插入与删除

push_back(ele)   尾部插入ele

pop_back();        尾部删除最后一个元素

inser(const_iterator pos,ele);  迭代器指向位置pos,插入元素ele

inser(const_iterator pos,int count,ele); 迭代器指向位置pos,插入count个元素ele

erase(const_iterator pos);     删除迭代器指向的元素

erase(const_iterator start,const_iterator end); 删除迭代器从start到end之间的元素

clear();删除容器中所有的元素

代码示例+注释

void test()
{
	//创建容器v1,往里面存放0~9
	vector<int>v1;
	for (int i = 0; i < 10; i++)
	{
		v1.push_back(i);
	}
	//尾插
	v1.push_back(20);
	//尾删
	v1.pop_back();
	//插入  第一个参数是迭代器 在第一个元素前插入一个100
	v1.insert(v1.begin(), 100);
	//在第一行元素前插10个100
	v1.insert(v1.begin(),10,100);
	//删除第一个元素
	v1.erase(v1.begin());
	//清空
	v1.erase(v1.begin(),v1.end());
	//清空
	v1.clear();
}

vector数据存取

at(int idx);  返回索引idx所指向的数据

operator[ ]        返回索引idx所致的数据

front(); 返回容器中第一个元素

back(); 返回容器中最后一个元素

void test()
{
	//创建容器v1,往里面存放0~9
	vector<int>v1;
	for (int i = 0; i < 10; i++)
	{
		v1.push_back(i);
	}
	//利用【】方式访问数组中的元素
	for (int i = 0; i < v1.size(); i++)
	{
		cout << v1[i] << endl;
	}
	//利用成员函数at()访问
	for (int i = 0; i < v1.size(), i++)
	{
		cout << v1.at(i) << endl;
	}
	//获取第一个元素
	cout << "第一个元素:  " << v1.front() << endl;
	//获取最后一个元素
	cout << "第一个元素:  " << v1.back() << endl;
}

vector互换容器

两个容器内的元素互换

swap(vec)//将传进来的容器与本身的元素互换

用法:

void test()
{
	//创建容器v1,往里面存放0~9
	vector<int>v1;
	for (int i = 0; i < 10; i++)
	{
		v1.push_back(i);
	}
	//创建容器v1,往里面存放9~0
	vector<int>v2;
	for (int i = 10; i > 0; i--)
	{
		v2.push_back(i);
	}
	v1.swap(v2);
}

用途:可以收缩空间

详细请看代码注释部分

void test01()
{
	vector<int>v1;
	for (int i = 0; i < 100000; i++)
	{
		v1.push_back(i);
	}
	cout << "v1的容量为:" << v1.capacity() << endl;
	cout << "v1的大小为:" << v1.size() << endl;
	//重新指定大小(容量依旧不发生改变)
	v1.resize(3);
	cout << "v1的容量为:" << v1.capacity() << endl;
	cout << "v1的大小为:" << v1.size() << endl;
	//利用swap进行收缩
	//vector<int>(v1):实际上是在创建一个新的临时向量对象,并将其与 v1 进行交换。
	//收缩向量 v1 的容量到其当前大小,从而释放多余的未使用内存。
	//因为 std::vector 的 swap() 操作会交换两个向量的内容和容量,而临时向量在析构时会释放其分配的内存。
	vector<int>(v1).swap(v1);
	cout << "v1的容量为:" << v1.capacity() << endl;
	cout << "v1的大小为:" << v1.size() << endl;
}

vector预留空间

目的:减少vector容器在动态扩展时的扩展次数

reserve(int len):容器预留len个元素长度,预留的位置不进行初始化,元素也不可访问

插入十万个数据,vector容器需要动态扩展30次

直接预留100000数据的空间仅需要一次

仅需v1.reserve(100000)

void test01()
{
	int num = 0;
	int* p = NULL;
	vector<int>v1;
	for (int i = 0; i < 100000; i++)
	{
		v1.push_back(i);
		if (p != &v1[0])
		{
			p = &v1[0];
			num++;
		}
	}
	cout << "需要动态扩展的次数: " << num << endl;

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

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

相关文章

软考高级证书拿到手了,怎么评职称?

软考&#xff0c;是以考代评&#xff0c;以一个考试来代替提交若干材料的评职称的过程。 但是评聘是分开的。就是指评审或考试后取得软考证书之后&#xff0c;也需要你们单位聘任你&#xff0c;才可以享受相应职称工资待遇&#xff0c;担任相应专业技术职位。 也就是说&#…

【FPGA】入门学习路线

文章目录 编程语言语法RTL设计RTL验证学习方法仿真工具 基础知识&#xff08;1&#xff09;专业基础课&#xff08;2&#xff09;FPGA相关专业知识&#xff08;3&#xff09;FPGA开发流程 开发工具动手实验 编程语言 硬件描述语言HDL&#xff08;Hardware Description Languag…

项目型企业管理系统有哪些?这10款值得研究

国内外主流的 10 款企业项目管理系统对比&#xff1a;PingCode、Worktile、泛微 e-office、金蝶云星瀚、用友项目管理软件、Jira、Monday.com、Asana、Trello、Basecamp。 在面对复杂的项目管理需求时&#xff0c;许多企业经常感到手头的工具不足以支撑高效的运作。有效的项目型…

代码随想录刷题day17丨654.最大二叉树,617.合并二叉树,700.二叉搜索树中的搜索,98.验证二叉搜索树

代码随想录刷题day17丨654.最大二叉树&#xff0c;617.合并二叉树&#xff0c;700.二叉搜索树中的搜索&#xff0c;98.验证二叉搜索树 1.题目 1.1最大二叉树 题目链接&#xff1a;654. 最大二叉树 - 力扣&#xff08;LeetCode&#xff09; 视频讲解&#xff1a;又是构造二叉…

【GeoscenePro】Pro连接本机Portal

打开自己的portal下面框住的就是链接的地址 证书的话点击是即可

嵌入式数据库

概述 1.作用&#xff1a;存储大量数据&#xff0c;专业存储数据 存储在内存&#xff08;数组&#xff0c;变量&#xff0c;链表&#xff09;上的特点&#xff1a;程序运行结束&#xff0c;或者掉电&#xff0c;数据会丢失。 存储在硬盘&#xff08;文件&#xff09;上的特点…

恺英网络:有业绩,无“游戏”

2024年上半年&#xff0c;恺英网络的业绩依然很好&#xff0c;但有些不讲逻辑了。 8月22日晚&#xff0c;恺英网络发布了2024年半年度财报。 报告显示&#xff0c;上半年公司实现营业收入25.55亿元&#xff0c;同比增长29.28%&#xff1b;归母净利润和扣非净利润分别为8.09亿…

鸿蒙开发5.0【基于Search组件实现搜索栏】

场景一&#xff1a;自定义搜索图标 方案 基于Search组件的searchIcon属性设置搜索图标&#xff0c;searchIcon可以设置size、color。注意&#xff1a;当前搜索图标不支持隐藏且不支持位置调整。基于searchButton属性设置搜索框末尾搜索按钮。基于该属性可更改文本内容及文本样…

Pepper佩盼尔wordpress模板

Pepper佩盼尔WordPress模板是一款专为追求简洁、现代和专业外观的网站设计者和开发者打造的高品质主题。它以简站为主题&#xff0c;强调“让建网站更简单”的理念&#xff0c;旨在为用户提供一个易于使用、功能丰富的平台来构建他们的在线业务或个人网站。 模板特点包括&…

【JavaEE】网络原理 UDP协议

&#x1f525;个人主页&#xff1a; 中草药 &#x1f525;专栏&#xff1a;【Java】登神长阶 史诗般的Java成神之路 &#x1f383;一.运输层 运输层&#xff08;Transport Layer&#xff09;是OSI七层模型中的第四层&#xff0c;也是TCP/IP四层模型中的第三层。它的主要职责是…

在3D Slicer中使用 Monai Bundle 和 Model Zoo 标注医学影像数据-全身CT器官分割

在3D Slicer中使用 Monai Bundle 和 Model Zoo 标注医学影像数据-全身CT器官分割 文章持续更新&#xff0c;可以关注微公【医学图像人工智能实战营】获取最新动态。人手有限&#xff0c;文中涉及的链接前往微公对应文章查看。关注Tina姐&#xff0c;一起学习进步~ 导读 本系列…

云计算基础之Docker

云计算是什么 云计算的本质是计算资源的虚拟化。 与磁盘逻辑卷的分配类似&#xff0c;云计算是在负载波动时动态调整服务器计算资源&#xff0c;避免资源浪费的做法&#xff0c;生产环境中&#xff0c;厂商一般将服务器组成一个池&#xff0c;实现逻辑管理计算资源&#xff0…

实时图像编辑大革新!Adobe发布TurboEdit:可以通过文本来编辑图像,编辑时间<0.5秒!

今天给大家介绍Adobe研究院新的研究TurboEdit&#xff0c;可以通过文本来编辑图像&#xff0c;通过一句话就能改变图像中的头发颜色、衣服、帽子、围巾等等。而且编辑飞快&#xff0c;<0.5秒。简直是图像编辑的利器。 相关链接 项目&#xff1a;betterze.github.io/TurboE…

闪存刷新机制文献的解读

闪存刷新机制文献的解读 一、文献信息1、标题&#xff1a;Flash Correct-and-Refresh: Retention-Aware Error Management for Increased Flash Memory Lifetime2、作者来源&#xff1a;卡耐基梅隆大学 二、Motivation三、Technique ( Flash Correct-and-Refresh, FCR )1、Repr…

如何使用Svg矢量图封装引用到vue3项目中

前言 在现代前端开发中&#xff0c;SVG&#xff08;可缩放矢量图形&#xff09;因其高质量和灵活性成为了图标和图形设计的热门选择。对于 Vue 3 项目而言&#xff0c;将 SVG 图标封装和引用到项目中不仅能提升性能&#xff0c;还能带来更高的可维护性和一致性。SVG 图标本质上…

LED的使用寿命评估

一&#xff0e;前言 LED光源随着时间的推移&#xff0c;输出光功率会逐渐衰减。在某一时间点&#xff0c;当LED发出的光衰减到一定水平&#xff0c;就无法满足应用要求。因此&#xff0c;常遇见客户会索取产品中LED光源的使用寿命数据。那么怎样确认LED的使用寿命呢&#xff1…

视觉Mamba综述——Visual Mamba: A Survey and New Outlooks论文总结

Visual Mamba: A Survey and New Outlooks &#xff08;31页&#xff0c;视觉Mamba综述&#xff09; 香港科技大学计算机科学与工程系 https://github.com/Ruixxxx/Awesome-Vision-Mamba-Models. 任务背景 0.摘要 Mamba是最近提出的一种选择性结构化状态空间模型&#xff…

公共DNS大测评,哪个解析性能最好?

日前阿里云方面发布公告称&#xff0c;由于产品升级&#xff0c;将于2024年9月30日24时起对公共DNS中免费的解析请求采取智能流量管控措施。据其透露&#xff0c;“公共DNS仍会致力于为广大免费用户提供高质量的基础递归解析服务&#xff0c;但在高并发解析场景&#xff0c;将对…

建模杂谈系列249 增量数据的正态分布拟合

说明 从分布开始&#xff0c;分布又要从正态开始 假设有一批数据&#xff0c;只有通过在线的方式增量获得。 内容 1 生成 先通过numpy生成一堆随机数据&#xff0c;从3个正态分布生成&#xff0c;然后拼接起来。 import numpy as np import matplotlib.pyplot as plt from …

【智能算法改进】路径规划问题的多策略改进樽海鞘群算法研究

目录 1.算法原理2.改进点3.结果展示4.参考文献5.代码获取 1.算法原理 【智能算法】樽海鞘群算法&#xff08;SSA)原理及实现 2.改进点 无标度网络策略 复杂网络在图论中可以用边和节点表示&#xff0c; Barabasi 等于1999年通过分析大量的数据提出了无标度网络模型. 该网络…