C++之初识STL—vector

news2024/12/28 4:40:23

文章目录

  • STL基本概念
  • 使用STL的好处
  • 容器
  • vector
    • 1.vector容器简介
    • 2.vector对象的默认构造函数
    • 3.vector对象的带参构造函数
    • 4.vector的赋值
    • 5.vector的大小
    • 6.vector容器的访问方式
    • 7.vector的插入

STL基本概念

  • STL(Standard Template Library,标准模板库)
  • STL 从广义上分为: 容器(container) 算法(algorithm) 迭代器(iterator)
  • 迭代器:算法通过迭代器访问容器里面的数据
  • 容器和算法之间通过迭代器进行无缝连接。
  • STL 几乎所有的代码都采用了模板类或者模板函数,这相比于传统的由函数和类组成的库来说提供了更好的代码重用机会

使用STL的好处

  • STL是C++的一部分,因此不需要额外安装什么,被内建在你的编译器里面
  • STL的一个重要特点是将数据结构和算法分离
  • 程序员不用思考STL的实现过程
  • STL具有高可用性,高性能,高移植,跨平台优点

容器

序列式容器:

  • 序列式容器每个元素都有固定位置–取决于插入的时机和地点,和元素值无关。
  • vector,deque、list、stack、queue

关联式容器:

  • 元素位置取决于特定的排序准则,和插入顺序无关
  • set、multiset、map、multimap

在这里插入图片描述
在这里插入图片描述

vector

1.vector容器简介

  • 尾部插入速度比较快
  • vector是将元素置于一个动态数组中加以管理的容器
  • vector可以随机存取元素(支持索引值直接存取)
  • vector尾部添加或移除元素的速度非常快速,但是在头部插入或移除元素比较费时

2.vector对象的默认构造函数

vector<class T>vecT;
vector<int>vecInt;
vector<float>vecFloat;
vector<string>vecString;

class A{};
vector<A>vecA; //用于存放CA对象的vector容器,
//由于容器元素的存放是按值复制的方式进行,所以此时CA必须提供CA的拷贝构造函数,以保证CA对象间拷贝正常

vector<A*>vecpA;   //用于存放CA对象指针的vector容器

3.vector对象的带参构造函数

理论知识:

  • vector(beg,end); //构造函数将[beg,end)区间中的元素拷贝给本身,注意该区间左闭右开
  • vector(n,elem);//构造函数将n个elem拷贝给本身
  • vector(const vector& vec); //拷贝构造函数
int main()
{
	int arr[] = { 1,2,3,4,5 }; //用两个指针构造
	vector<int>v1(arr, arr + 5);

	vector<int>v2(3, 10);//存储3个10
	for (int i = 0; i < v2.size(); i++)
	{
		cout << v2[i] << " ";
	}
	cout << endl;
	vector<int>v3(v1);//用一个已经构造好的对象初始化新的对象
	for (int i = 0; i < v1.size(); i++)
	{
		cout << v3[i] << " ";
	}
}

在这里插入图片描述

4.vector的赋值

  • vector.assign(beg,end);//将[beg,end)区间中的元素拷贝赋值给本身,注意该区间左闭右开
  • vector.assign(n,elem);//将n个elem拷贝赋值给本身
  • vector& operator=(const vector& vec);//重载等号操作符
  • vector.swap(vec); //将vec与本身的元素互换
int main()
{
	vector<int>vecIntA(3, 10);
	vector<int> vecIntB, vecIntC, vecIntD;
	int iarray[] = { 0,1,2,3,4 };

	//将数组iarray中的所有元素赋值给vactorIntA容器
	vecIntA.assign(iarray, iarray + 5);
	cout << "A:";
	for (int i = 0; i < vecIntA.size(); i++)
	{
		cout <<vecIntA[i] << " ";
	}
	cout << endl;

	//将vecIntA中所有元素赋值给vecIntB
	vecIntB.assign(vecIntA.begin(), vecIntA.end());
	cout << "B1:";
	for (int i = 0; i < vecIntB.size(); i++)
	{
		cout <<vecIntB[i] << " ";
	}
	cout << endl;

	cout << "B2:";
	vecIntB.assign(vecIntA.begin()+2, vecIntA.end()-1);
	for (int i = 0; i < vecIntB.size(); i++)
	{
		cout << vecIntB[i] << " ";
	}
	cout << endl;

	//将4个10拷贝到vecIntC
	vecIntC.assign(4, 10);
	cout << "C:";
	for (int i = 0; i < vecIntC.size(); i++)
	{
		cout<< vecIntC[i] << " ";
	}
	cout << endl;

	//互换元素
	vecIntB.swap(vecIntC);
	cout << "B2:";
	for (int i = 0; i < vecIntB.size(); i++)
	{
		cout <<vecIntB[i] << " ";
	}
	cout << endl;

	cout << "C:";
	for (int i = 0; i < vecIntC.size(); i++)
	{
		cout << vecIntC[i] << " ";
	}
	cout << endl;

	//重载赋值运算符
	vecIntD = vecIntC;
	cout << "D:";
	for (int i = 0; i < vecIntD.size(); i++)
	{
		cout << vecIntD[i] << " ";
	}
	return 0;
}

在这里插入图片描述

5.vector的大小

  • vector.size(); //返回容器中元素的个数
  • vector.empty(); //判断容器是否为空
  • vector.resize(); //重新指定容器的长度为num,若容器变长,则以默认值填充新位置。如果容器变短,则末尾超出容器长度的元素被删除
  • vector.resize(num,elem);//重新指定容器的长度为num,若容器变长,则以elem填充新位置。如果容器变短,则末尾超出容器长度的元素被删除
int main()
{
	vector<int>v1;
	cout << "v1.size: " <<v1.size()<< endl;
	if (v1.empty()) //判断容器是否为空
	{
		cout << "v1 is empty" << endl;
	}

	int array[] = { 1,2,3,4,5 };
	v1.assign(array, array + 5);

	//将容器的长度变长
	v1.resize(10);
	for (int i = 0; i < v1.size(); i++)
	{
		cout << v1[i] << " ";
	}
	cout << endl;

	//将容器长度变短
	v1.resize(3);
	for (int i = 0; i < v1.size(); i++)
	{
		cout << v1[i] << " ";
	}
	cout << endl;

	//将容器长度变长,并且扩展出来的新的元素为指定的值
	v1.resize(10, 100);
	for (int i = 0; i < v1.size(); i++)
	{
		cout << v1[i] << " ";
	}
	cout << endl;
	return 0;
}

在这里插入图片描述

6.vector容器的访问方式

  • vec.at[idx]; //返回索引idx所指数据,如果idx越界,抛出out_of_range异常
  • vec[idx]; //返回索引idx所指的数据,越界时,运行直接报错
    在这里插入图片描述

7.vector的插入

  • 在vector末尾进行插入:push_back、在末尾删除元素:pop_back
  • vector.insert(pos,elem); //在pos位置插入一个elem元素的拷贝,返回新数据的位置
  • vector.insert(pos,n,elem);//在pos位置插入n个elem数据,无返回值
  • vector.insert(pos,beg,end); //在pos位置插入[beg,end)区间的数据,无返回值
int main()
{
	int arr[] = { 1,2,3,4,5 };
	vector<int>v1(arr, arr + 5);

	//在末尾插入函数
	v1.push_back(10);

	//在末尾删除函数
	v1.pop_back();

	//在指定位置插入一个指定元素
	v1.insert(v1.begin()+3,100); //注意第一个参数不能为下标,应该为指针
	for (int i = 0; i < v1.size(); i++)
	{
		cout << v1[i] << " ";
	}
	cout << endl;

	//在指定的位置插入多个元素
	v1.insert(v1.begin() + 3, 3, 1000);//在下标为3的位置上插入3个1000
	for (int i = 0; i < v1.size(); i++)
	{
		cout << v1[i] << " ";
	}
	cout << endl;

	//将指定的区间中的元素插入到指定的位置上,将50—80插入
	int b[] = { 40,50,60,70,80,90 };
	v1.insert(v1.begin() + 7, b + 1, b + 5);
	for (int i = 0; i < v1.size(); i++)
	{
		cout << v1[i] << " ";
	}
	cout << endl;
}

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

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

相关文章

springboot+vue音乐翻唱与分享平台(源码+文档)

风定落花生&#xff0c;歌声逐流水&#xff0c;大家好我是风歌&#xff0c;混迹在java圈的辛苦码农。今天要和大家聊的是一款基于springboot的音乐网站与分享平台。项目源码以及部署相关请联系风歌&#xff0c;文末附上联系信息 。 &#x1f495;&#x1f495;作者&#xff1a;…

基于 FineReport 快速设计联动报表

一、基于 FineReport 快速设计联动报表 FineReport 一款用于报表制作&#xff0c;分析和展示的工具&#xff0c;可以轻松的构建出灵活的数据分析和报表系统。 下面基于 FineReport 自带的数据表 销量 表快速设计一页可视化联动报表&#xff0c;数据格式如下&#xff1a; 报表…

最新最全花1W买的Python+Selenium全栈Web自动化测试

前言&#xff1a;看这篇帖子&#xff0c;最好要在知道定位八大元素的基础之上才能够比较熟练的看完这篇帖子自动化测试是软件开发中非常重要的一环&#xff0c;它可以帮助开发人员提高代码质量、减少错误和缺陷&#xff0c;并节省测试时间。其中&#xff0c;Selenium是一个广泛…

01- 目标检测 (综述)

要点&#xff1a; 区分One-stage detector 和 Two-stage detector 参考链接&#xff1a;深度学习目标检测最全综述 - 爱码网 详细模型解读参考&#xff1a;目标检测简介 - 知乎 一 目标检测分类 1.1 发展历程 检测网络发布历程&#xff1a; 1.2 检测模型分类 2014年后目标…

7---整数反转

给你一个 32 位的有符号整数 x x x &#xff0c;返回将 x x x 中的数字部分反转后的结果。 如果反转后整数超过 32 位的有符号整数的范围 [ − 2 31 , 2 31 − 1 ] [−2^{31}, 2^{31} − 1] [−231,231−1]&#xff0c;就返回 0。 假设环境不允许存储 64 位整数&#xff08…

2017年上半年软件设计师下午试题

试题四 阅读下列说明和 C 代码&#xff0c;回答问题 1 至问题 3&#xff0c;将解答写在答题纸的对应栏内。 【说明】 假币问题&#xff1a;有 n 枚硬币&#xff0c;其中有一枚是假币&#xff0c;己知假币的重量较轻。现只有一个天平&#xff0c;要求用尽量少的比较次数找出这枚…

【编程福音,25款必备AI编码工具推荐,让你事半功倍】

&#x1f680; AI破局先行者 &#x1f680; &#x1f332; AI工具、AI绘图、AI专栏 &#x1f340; &#x1f332; 如果你想学到最前沿、最火爆的技术&#xff0c;赶快加入吧✨ &#x1f332; 作者简介&#xff1a;硕风和炜&#xff0c;CSDN-Java领域优质创作者&#x1f3c6;&am…

代码随想录算法训练营第三十四天 | 加油站题、左右贪心

1005. K次取反后最大化的数组和 文档讲解&#xff1a;代码随想录 (programmercarl.com) 视频讲解&#xff1a;贪心算法&#xff0c;这不就是常识&#xff1f;还能叫贪心&#xff1f;LeetCode&#xff1a;1005.K次取反后最大化的数组和_哔哩哔哩_bilibili 状态&#xff1a;能做出…

Hadoop的安装与配置

Hadoop的安装与配置 推荐按照我的博客下载hadoop&#xff0c;spark&#xff0c;pyspark以及scala这样版本搭配更好。 如果觉得自己不会版本搭配可私聊博主。 scala的安装和配置&#xff1a;https://blog.csdn.net/weixin_41957626/article/details/130548174 spark的安装和配置…

宇树Unitree机器狗连接外网的一种方法

宇树官方提供的方式&#xff1a; ​​​​​​​ 宇树机器狗连接网络的相关说明 (yuque.com) 我这里提供一种我采用的方式&#xff0c;仅供参考&#xff1a; 需要一根手机数据线&#xff0c;能联网的手机 我这里使用的是小米手机&#xff0c;其余手机大概也能行。 如下&…

ElasticSearch学习随笔之高级检索

ElasticSearch 1、ElasticSearch学习随笔之基础介绍 2、ElasticSearch学习随笔之简单操作 3、ElasticSearch学习随笔之java api 操作 4、ElasticSearch学习随笔之SpringBoot Starter 操作 5、ElasticSearch学习随笔之嵌套操作 6、ElasticSearch学习随笔之分词算法 7、ElasticS…

强化学习_06_pytorch-TD3实践(BipedalWalkerHardcore-v3)

基于策略的离线算法TD3 1.1 简介 reference: openai-TD3 DDPG的critic会高估, 从而导致actor策略失败。TD3是增加了三个关键技巧优化DDPG。经过优化后的TD3(Twin Dalayed DDPG 双延迟深度确定性策略梯度算法)适合于具有高维连续动作空间的任务。 Tricks: Clipped Double Q-l…

github学习笔记

目录 github简介 唯一版本库是什么意思 hub的含义什么&#xff1f; github功能介绍 登录、注册 GitHub 术语解释 Git 初体验及其常用命令介绍 git中的两个分支是否有冲突是什么意思&#xff0c;这是因为什么导致的 利用 SSH 完成 Git 与 GitHub 的绑定 通过 Git 将代…

[ Azure 云计算从业者 | AZ-900 ] Chapter 06 | 认识与了解 Azure 中相关的计算服务

本章节主要内容进行讲解&#xff1a;计算服务中的虚拟机 VM、虚拟机规模集 VMSS、Azure 容器&#xff08;ACI&#xff09;、Azure Kubernetes Service (AKS) 与Azure Functions 本系列已经更新文章列表&#xff08;已更新&#xff09;&#xff1a; [ Azure 云计算从业者 | AZ…

Java 基础进阶篇(十一)—— 泛型与可变参数

文章目录 一、泛型概述二、泛型的定义2.1 泛型类2.2 泛型方法2.3 泛型接口 三、泛型深入3.1 泛型通配符3.2 泛型上下限3.3 案例&#xff1a;定义一个 “所有车量进行比赛” 的方法 四、可变参数 一、泛型概述 泛型是 JDK5 中引入的特性&#xff0c;可以在编译阶段约束操作的数…

从源码全面解析Java 线程池的来龙去脉

&#x1f44f;作者简介&#xff1a;大家好&#xff0c;我是爱敲代码的小黄&#xff0c;独角兽企业的Java开发工程师&#xff0c;CSDN博客专家&#xff0c;阿里云专家博主&#x1f4d5;系列专栏&#xff1a;Java设计模式、Spring源码系列、Netty源码系列、Kafka源码系列、JUC源码…

二叉树专题

⭐️前言⭐️ 本文主要总结一些常见的二叉树题目&#xff0c;希望读者能够通过这篇文章&#xff0c;来对二叉树有一个更深一步的了解。 &#x1f349;欢迎点赞 &#x1f44d; 收藏 ⭐留言评论 &#x1f4dd;私信必回哟&#x1f601; &#x1f349;博主将持续更新学习记录收获&…

【移动端网页布局】flex 弹性布局 ⑥ ( 设置侧轴多行子元素排列方式 | align-content 样式说明 | 代码示例 )

文章目录 一、设置侧轴多行子元素排列方式 : align-content 样式说明1、align-content 样式引入2、align-content 样式属性值 二、代码示例1、代码示例 - 侧轴多行元素从上到下排列2、代码示例 - 侧轴多行元素垂直居中3、代码示例 - 侧轴多行元素平分剩余空间4、代码示例 - 侧轴…

1960-2014年各国二氧化碳排放量(人均公吨数)

1960&#xff0d;2014年各国二氧化碳排放量&#xff08;人均公吨数&#xff09;&#xff08;世界发展指标, 2019年12月更新&#xff09; 1、来源&#xff1a;世界发展指标 2、时间&#xff1a;1960&#xff0d;2014年 3、范围&#xff1a;世界各国 4、指标&#xff1a; 二氧…

C++ STL:set和map的结构及接口使用

目录 一. set和map的简介 1.1 set的简介 1.2 map的简介 二. set的主要接口函数及使用方法 2.1 构造及赋值相关接口函数 2.2 通过迭代器遍历set 2.3 结构修改相关接口函数 2.4 其他主要接口函数 三. map的主要接口函数及使用方法 3.1 构造和赋值相关接口函数 3.2 通…