【C++初阶】第九站:vector的介绍及使用

这篇具有很好参考价值的文章主要介绍了【C++初阶】第九站:vector的介绍及使用。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

前言:

🎯个人博客:Dream_Chaser

🎈博客专栏:C++

📚本篇内容:vector的介绍及使用

【C++初阶】第九站:vector的介绍及使用,C++,c++,vs2019,编程语言,c语言,vector

目录

一、vector的介绍

二、vector的使用

1.vector的定义

2.vector iterator(迭代器)的使用

begin和end(正向迭代器)

rbegin和rend(反向迭代器)

3.vector 空间增长问题

size和capacity

max_size

reserve和resize

empty

4.vector 增删查改

push_back和pop_back

insert

find

erase

clear 和 shrink_to_fit


一、vector的介绍

1.1 vector的介绍

vector的文档介绍

1. vector是表示可变大小数组的序列容器。

2. 就像数组一样,vector也采用的连续存储空间来存储元素。也就是意味着可以采用下标对vector的元素 进行访问,和数组一样高效。但是又不像数组,它的大小是可以动态改变的,而且它的大小会被容器自动处理。

3. 本质讲,vector使用动态分配数组来存储它的元素。当新元素插入时候,这个数组需要被重新分配大小为了增加存储空间。其做法是,分配一个新的数组,然后将全部元素移到这个数组。就时间而言,这是一个相对代价高的任务,因为每当一个新的元素加入到容器的时候,vector并不会每次都重新分配大小。

4. vector分配空间策略:vector会分配一些额外的空间以适应可能的增长,因为存储空间比实际需要的存储空间更大。不同的库采用不同的策略权衡空间的使用和重新分配。但是无论如何,重新分配都应该是对数增长的间隔大小,以至于在末尾插入一个元素的时候是在常数时间的复杂度完成的。

5. 因此,vector占用了更多的存储空间,为了获得管理存储空间的能力,并且以一种有效的方式动态增长。

6. 与其它动态序列容器相比(deque, list and forward_list), vector在访问元素的时候更加高效,在末尾添加和删除元素相对高效。对于其它不在末尾的删除和插入操作,效率更低。比起list和forward_list统一的迭代器和引用更好。

二、vector的使用

vector学习时一定要学会查看文档vector的文档介绍,vector在实际中非常的重要,在实际中我们熟悉常见的接口就可以,下面列出了哪些接口是要重点掌握的。

1.vector的定义

【C++初阶】第九站:vector的介绍及使用,C++,c++,vs2019,编程语言,c语言,vector

方式一:创建一个空的整数容器v1,不包含任何元素

vector<int> v1;

方式二:创建一个包含10个初始值为0的整数的容器v2

vector<int> v2(10, 0);

方式三:创建一个容器v3,其元素是通过复制v2容器的起始位置到结束位置的元素而来(v3包含了v2的所有元素)

vector<int> v3(v2.begin(), v2.end());

方式四:创建一个整数容器v4,其元素是通过将字符串s的字符转换为对应的ASCII码并复制而来

字符串迭代器在此上下文中会依次指向每个字符,因此v4包含了s中每个字符的ASCII值

// 创建一个字符串s,内容为"hello world"
string str("hello world");
vector<int> v4(str.begin(),str.end());

方式五: v5通过拷贝构造函数初始化,包含与v4相同的元素

vector<int> v5(v4);// 创建一个容器v5,它是容器v4的一个副本

2.vector iterator(迭代器)的使用

【C++初阶】第九站:vector的介绍及使用,C++,c++,vs2019,编程语言,c语言,vector

for循环的遍历方式

void test_vector1()
{
	vector<int> v1;
	vector<int> v2(10, 0);
	vector<int> v3(v2.begin(), v2.end());
    //for循环遍历
	for (size_t i = 0; i < v3.size(); i++)
	{
		cout << v3[i] << " ";
	}
	cout << endl;
}
int main()
{
	test_vector1();
}

【C++初阶】第九站:vector的介绍及使用,C++,c++,vs2019,编程语言,c语言,vector

begin和end(正向迭代器)

begin函数返回指向容器内第一个元素的迭代器,end函数返回指向vector容器中末尾元素的下一个位置的迭代器。

【C++初阶】第九站:vector的介绍及使用,C++,c++,vs2019,编程语言,c语言,vector

正向迭代器遍历容器:

#include<iostream>
#include<vector>
using namespace std;
void test_vector1()
{
	string str("hello world");
	vector<int> v4(str.begin(),str.end());
	vector<int>::iterator it = v4.begin();
//	auto it = v4.begin();
	while (it != v4.end())
	{
		cout << *it << " ";
		++it;
	}
	cout << endl;
}

【C++初阶】第九站:vector的介绍及使用,C++,c++,vs2019,编程语言,c语言,vector

rbegin和rend(反向迭代器)

rbegin:返回一个指向容器中的最后一个位置的元素的迭代器

rend:返回一个指向容器中的第一个位置的元素的前一个元素的迭代器

【C++初阶】第九站:vector的介绍及使用,C++,c++,vs2019,编程语言,c语言,vector

反向迭代器遍历容器:

#include<iostream>
#include<vector>
using namespace std;
void test_vector1()
{
    vector<int>::reverse_iterator rit = v4.rbegin();
    while (rit != v4.rend())
    {
	    cout << *rit << " ";
	    ++rit;
    }
}

【C++初阶】第九站:vector的介绍及使用,C++,c++,vs2019,编程语言,c语言,vector

范围for方式遍历

void test_vector1()
{
	string str("hello world");
	vector<int> v4(str.begin(),str.end());
	vector<int> v5(v4);
	for (auto e : v5)
	{
		cout << e << " " ;
	}
	cout << endl;
}

【C++初阶】第九站:vector的介绍及使用,C++,c++,vs2019,编程语言,c语言,vector

3.vector 空间增长问题

【C++初阶】第九站:vector的介绍及使用,C++,c++,vs2019,编程语言,c语言,vector

size和capacity

通过size函数获取当前容器中的有效元素个数,通过capacity函数获取当前容器的最大容量。

#include <iostream>
#include <vector>
using namespace std;

int main()
{
	vector<int> v(10, 2);
	cout << v.size() << endl; //获取当前容器中的有效元素个数
	cout << v.capacity() << endl; //获取当前容器的最大容量
	return 0;
}

【C++初阶】第九站:vector的介绍及使用,C++,c++,vs2019,编程语言,c语言,vector

vs2019和g++扩容机制的对比:

//在两种不同的编译器下使用相同的代码
#include<iostream>
#include<vector>
using namespace std;
void test_vector2()
{
	size_t sz;
	vector<int> v;
	sz = v.capacity();
	cout << "making v grow:\n";
	for (int i = 0; i < 100; i++)
	{
		v.push_back(i);
		if (sz != v.capacity())
		{
			sz = v.capacity();
			cout << "capacity changed:"<<sz<<endl;
		}
	}
}
int main()
{
	test_vector2();
}

【C++初阶】第九站:vector的介绍及使用,C++,c++,vs2019,编程语言,c语言,vector

  • capacity的代码在vs和g++下分别运行会发现,vscapacity是按1.5倍增长的,g++是按2倍增长的。 这个问题经常会考察,不要固化的认为,vector增容都是2倍,具体增长多少是根据具体的需求定义的。vs是PJ版本STL,g++是SGI版本STL。

max_size

是一个固定的值:

【C++初阶】第九站:vector的介绍及使用,C++,c++,vs2019,编程语言,c语言,vector

reserve和resize

reserve函数改变容器的最大容量,resize函数改变容器中的有效元素个数

reserve规则:

【C++初阶】第九站:vector的介绍及使用,C++,c++,vs2019,编程语言,c语言,vector

n>capacity:如果n大于当前容器的容量,该函数使容器重新分配存储空间,将其容量增加到n(或更大)。

n <= capacity:其他情况来说,该函数不会影响容器重新分配存储空间和容器的容量不会受到影响。

该函数不会影响容器的有效数据个数(size)和不会改变它原本的元素。

如果说需要提前开好空间,避免频繁扩容,就可以使用reserve函数:
// 如果已经确定vector中要存储元素大概个数,可以提前将空间设置足够
// 就可以避免边插入边扩容导致效率低下的问题了
void test_vector2()
{
	size_t sz;
	vector<int> v;
	v.reserve(100); // 提前将容量设置好,可以避免一遍插入一遍扩容
	sz = v.capacity();
	cout << "making v grow:\n";
	for (int i = 0; i < 100; i++)
	{
		v.push_back(i);
		if (sz != v.capacity())
		{
			sz = v.capacity();
			cout << "capacity changed:"<<sz<<endl;
		}
	}
}
【C++初阶】第九站:vector的介绍及使用,C++,c++,vs2019,编程语言,c语言,vector
  • reserve 只负责开辟空间,如果确定知道需要用多少空间, reserve 可以缓解 vector 增容的代价缺陷问题。
以下这种情况 可以访问吗
【C++初阶】第九站:vector的介绍及使用,C++,c++,vs2019,编程语言,c语言,vector

不能,这里虽然空间是开出来了,但不能访问,原因是这个[ ]里面加了个断言,访问的下标必须是小于size,(此时的size应该为0,因为reserve不改变size),顺序表与数组有个区别,有个规定:你的数据必须是0到size-1,访问数据时是连续访问的,所以你只能访问0 ~ size-1的数据,那此时的size-1=-1,但是你访问了V[ 0 ]的数据,所以报错就报在这个断言上面了

【C++初阶】第九站:vector的介绍及使用,C++,c++,vs2019,编程语言,c语言,vector

那我要想访问这个数据怎么办呢?换成resize。

【C++初阶】第九站:vector的介绍及使用,C++,c++,vs2019,编程语言,c语言,vector

resize规则:

【C++初阶】第九站:vector的介绍及使用,C++,c++,vs2019,编程语言,c语言,vector

n < size:如果n小于当前容器的有效数据个数,它的内容被简化为前n个元素,移除后面的元素(并
摧毁它们)
n>size:如果n大于当前容器的有效数据个数,它的内容通过在末尾插入尽可能多的元素来扩展内容,使其大小达到n

如果指定了val,那么新添加的元素将被初始化为val的副本;否则,它们将进行值初始化。

如果n也大于当前容器的capacity,则会自动重新分配已分配的存储空间。

请注意,此函数通过插入或删除元素来改变容器的实际内容。

  • resize 在开空间的同时还会进行初始化,影响 size

empty

通过empty函数判断当前容器是否为空。

【C++初阶】第九站:vector的介绍及使用,C++,c++,vs2019,编程语言,c语言,vector

4.vector 增删查改

push_back和pop_back

push_back:在容器的最后一个元素之后添加一个新元素。将val的内容复制(或移动)到新元素中。

pop_back:删除容器中的最后一个元素,有效地将容器大小减少1。

void test_vector4()
{
	vector<int> v;
	v.push_back(4);
	v.push_back(3);
	v.push_back(2);
	v.push_back(1);
	//使用范围for遍历
	cout << "遍历:" << endl;
	for (auto e : v)
	{
		cout << e << " ";
	}
	cout << endl;
    v.pop_back();
	for (auto e : v)
	{
		cout << e << " ";
	}
}

【C++初阶】第九站:vector的介绍及使用,C++,c++,vs2019,编程语言,c语言,vector

insert

insert:通过在指定位置的元素之前插入新元素,可以有效地增加容器的大小。

【C++初阶】第九站:vector的介绍及使用,C++,c++,vs2019,编程语言,c语言,vector

void test_vector4()
{ 
    cout << "头插:" << endl;
	v.insert(v.begin(),0);//头插
	for (auto e : v)
	{
		cout << e << " ";
	}
	cout << endl;
}

【C++初阶】第九站:vector的介绍及使用,C++,c++,vs2019,编程语言,c语言,vector

find

返回范围[first,last)中与val相等的第一个元素的迭代器。如果没有找到这样的元素,则返回last。

如果说此时我要在3前面插入一个元素,我们可以发现vector没写对应的find,但是我们可以在全局(algorithm)找到一个find,这对于string、vector、list等容器都是通用的,只是说可能string的需求更复杂一点,需要单独去给string实现它的find。

【C++初阶】第九站:vector的介绍及使用,C++,c++,vs2019,编程语言,c语言,vector

【C++初阶】第九站:vector的介绍及使用,C++,c++,vs2019,编程语言,c语言,vector

test_vector4(){    
    cout << "在值为3前面的位置插入值为30的元素:";
	auto it = find(v.begin(),v.end(),3);//这里返回的指向3这个元素的的位置的迭代器
	if (it != v.end())
	{	//在下标为3的位置插入
		v.insert(it,30);//把元素3挤到后面一个位置
	}
	for (auto e : v)
	{
		cout << e << " ";
	}
	cout << endl;
}

erase

erase:从容器中删除一个元素(位置)或一个元素范围([第一,最后)]。

【C++初阶】第九站:vector的介绍及使用,C++,c++,vs2019,编程语言,c语言,vector

【C++初阶】第九站:vector的介绍及使用,C++,c++,vs2019,编程语言,c语言,vector

test_vector4()
{
    cout << "删除值为3的元素:";
	//返回值指向值为3的元素的迭代器,此迭代器指向了元素为3的这个位置
	it = find(v.begin(),v.end(),3);//下标为2
 	if (it != v.end())
	{
		v.erase(it);//it=2
	}
	for (auto e : v)
	{
		cout << e << " ";
	}
	cout << endl;
}

clear 和 shrink_to_fit

【C++初阶】第九站:vector的介绍及使用,C++,c++,vs2019,编程语言,c语言,vector

【C++初阶】第九站:vector的介绍及使用,C++,c++,vs2019,编程语言,c语言,vector

本章完。

🔧本文修改次数:0

🧭更新时间:2024年4月5日 文章来源地址https://www.toymoban.com/news/detail-857680.html

到了这里,关于【C++初阶】第九站:vector的介绍及使用的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • C++初阶(十三)vector

    📘北尘_ :个人主页 🌎个人专栏 :《Linux操作系统》《经典算法试题 》《C++》 《数据结构与算法》 ☀️走在路上,不忘来时的初心 vector的文档介绍 vector是表示可变大小数组的序列容器。 就像数组一样,vector也采用的连续存储空间来存储元素。也就是意味着可以采用下标对

    2024年02月04日
    浏览(24)
  • 【C++】vector介绍及使用

    🚀 作者简介:一名在后端领域学习,并渴望能够学有所成的追梦人。 🚁 个人主页:不 良 🔥 系列专栏:🛸C++  🛹Linux 📕 学习格言:博观而约取,厚积而薄发 🌹 欢迎进来的小伙伴,如果小伙伴们在学习的过程中,发现有需要纠正的地方,烦请指正,希望能够与诸君一同

    2024年02月15日
    浏览(27)
  • 【C++】vector的介绍与使用

      🧑‍🎓 个人主页:简 料   🏆 所属专栏:C++   🏆 个人社区:越努力越幸运社区   🏆 简       介: 简料简料,简单有料~在校大学生一枚,专注C/C++/GO的干货分享,立志成为您的好帮手 ~ C/C++学习路线 (点击解锁) ❤️ C语言 ❤️ 初阶数据结构与算法 ❤️ C++ ❤️

    2024年02月04日
    浏览(31)
  • [C++]vector的介绍及使用

    目录 C++:vector的使用                 1.vector的定义方式                 2.vector的空间增长                         size和capacity                         reserve和resize                         empty                 3.ve

    2024年02月08日
    浏览(32)
  • 编程语言比拼之Java VS C++

    学Java还是C++?   Java和C++都是非常受欢迎的编程语言,各有各的优势和适用场景。以下是对它们的简要比较: 性能:C++通常被认为是一种更高效的编程语言,适用于对性能要求较高的应用程序,如游戏开发、嵌入式系统和高频交易等。C++具有更接近底层的控制能力,允许开发

    2024年02月13日
    浏览(26)
  • C++初阶-vector类的模拟实现

    C++ STL中的vector就类似于C语言当中的数组,但是vector又拥有很多数组没有的接口,使用起来更加方便。 相比于STL中的string,vector可以定义不同的数据类型。 迭代器的本质可以暂时看作是指针,模拟实现vector,需要定义三个指针:指向起始位置_start,指向最后一个有效元素的下

    2024年02月04日
    浏览(145)
  • 【C++初阶】STL详解(四)vector的模拟实现

    本专栏内容为:C++学习专栏,分为初阶和进阶两部分。 通过本专栏的深入学习,你可以了解并掌握C++。 💓博主csdn个人主页:小小unicorn ⏩专栏分类:C++ 🚚代码仓库:小小unicorn的代码仓库🚚 🌹🌹🌹关注我带你学习编程知识 注:为了防止与标准库当中的vector产生命名冲突

    2024年02月05日
    浏览(33)
  • 【C++庖丁解牛】STL之vector容器的介绍及使用 | vector迭代器的使用 | vector空间增长问题

    🍁你好,我是 RO-BERRY 📗 致力于C、C++、数据结构、TCP/IP、数据库等等一系列知识 🎄感谢你的陪伴与支持 ,故事既有了开头,就要画上一个完美的句号,让我们一起加油 vector的文档介绍 vector是表示可变大小数组的序列容器。 就像数组一样,vector也采用的连续存储空间来存

    2024年03月14日
    浏览(62)
  • C++初阶之一篇文章让你掌握vector(模拟实现)

    模拟实现vector是为了深入理解和学习C++标准库中vector容器的工作原理和实现细节。 vector是C++标准库中最常用的容器之一,它提供了动态数组的功能,并且具有自动扩容和内存管理的特性,使得在使用时非常方便。 模拟实现vector有以下几个优点: 学习数据结构与算法 :实现

    2024年02月14日
    浏览(32)
  • 【C++初阶】STL详解(五)List的介绍与使用

    本专栏内容为:C++学习专栏,分为初阶和进阶两部分。 通过本专栏的深入学习,你可以了解并掌握C++。 💓博主csdn个人主页:小小unicorn ⏩专栏分类:C++ 🚚代码仓库:小小unicorn的代码仓库🚚 🌹🌹🌹关注我带你学习编程知识 1.list是一种可以在常数范围内在任意位置进行插

    2024年02月04日
    浏览(35)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包