百度360必应搜狗淘宝本站头条
当前位置:网站首页 > 编程字典 > 正文

C++数据结构之vector(c++vector详解)

toyiye 2024-07-06 00:21 10 浏览 0 评论

1、关于vector

vector数组是一个能存放任意数据类型(类,结构体,普通变量类型等)的动态数组,在数据结构中就相当于顺序储存的线性表,寻找元素非常快,但是插入元素的时间却很大(list是一个双向链表,在同一个位置插入大量的数据时速度很快,但是查找的速度就会慢很多)

和普通数组一样可以通过下标索引来进行访问

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

缺点:当新元素插入时候,这个数组需要被重新分配大小为了增加存储空间。其做法是,分配一个新的数组,然后将全部元素移到这个数组。就时间而言,这是一个相对代价高的任务,因为每当一个新的元素加入到容器的时候,vector并不会每次都重新分配大小。(比普通的数组具有更高的时间复杂度和空间复杂度)

2、定义、初始化

几种定义核初始化的方法:

vector<int> vec;        //声明一个int型向量
vector<int> vec1(4,1);   //vec1的内容为1,1,1,1
vector<int> vec2{ 1, 2, 3, 4, 5}; //vec2为1,2,3,4,5
vector<int> vec3(vec1); //也可以直接用vec3=vec1定义
vector<int> vec4(arr, arr + 5); //将arr数组的元素用于初始化vec向量
vector<int> vec5(arr,&arr[4]); //1,2,3,4
vector< vector<int> > vec2(8, vector<int> (8, 0)); //初始化二维数组
vector<int> dp[5][5]; //初始化二维数组,每个元素为一个vector
vec3.insert(vec3.end(),vec1.begin(),vec1.end()); //insert方法合并两个vector
vector<int> vec; vec.resize(n); // 也可视为一种初始化的方式

3、插入元素

vector<int> vec{1,2,3,4};
vec.push_back(1); //末尾插入 1,2,3,4,1

vector<int>::iterator it = vec.begin(); // 定义一个迭代器
vec.insert(it,2,5); //在第一个元素前插入2个5

vec.assign(2, 5); // 清除元素,然后插入2个5

使用?emplace??插入元素,对象会在容器中直接生成,而不是先单独生成对象,然后再把它作为参数传入。

【领QT开发教程学习资料,点击→「「链接」」←莬费领取,先码住不迷路~】

vector<int> vec{1,2,3,4};
auto iter = vec.emplace(++begin(vec),5);
vec.emplace(++iter, 6); // 1,5,6,2,3,4

与之对应的还有emplace_back,push_back() 向容器尾部添加元素时,首先会创建这个元素,然后再将这个元素拷贝或者移动到容器中(如果是拷贝的话,事后会自行销毁先前创建的这个元素);而 emplace_back() 在实现时,则是直接在容器尾部创建这个元素,省去了拷贝或移动元素的过程。

int x = 1, y=2;
vector<int> v1(10, x);
vector<int> v2(20, y);
v1.swap(v2);
cout << v1.size()<<'\t'<<v2.size()<< endl;
20  10

泛型swap释放vector的内存

因pop_back()和erase删除导致的占用空间

vector<int> v1(10, x);
v1.pop_back();
cout << v1.size() << '\t' << v1.capacity() << endl;
vector<int>(v1).swap(v1);
cout << v1.size()<<'\t'<<v1.capacity()<< endl;
v1.erase(v1.begin());
cout << v1.size() << '\t' << v1.capacity() << endl;
vector<int>(v1).swap(v1);
cout << v1.size() << '\t' << v1.capacity() << endl;

4、删除元素

vector<int> vec{1,2,3,4};
vec.pop_back(); //删除最后一个元素
vector<int>::iterator it;
it = vec.begin();
vec.erase(it); //删除迭代器指向的元素
vec.clear() // 清除所有元素
vec.empty() // 判断是否为空

5、遍历元素

迭代器

索引

for range

6、翻转和排序

vector<int> vec{1,2,3,4};
reverse(vec.begin(), vec.end()); //元素翻转
sort(vec.begin(), vec.end()); //采用的是从小到大的排序
bool Comp(const int& a, const int& b) {
    return a > b;
}
sort(vec.begin(), vec.end(), Comp); //自定义排序函数

7、注意问题

在使用迭代器删除和添加元素时要注意迭代器的变化。

7.1、删除元素

当使用??erase??删除元素时,返回的迭代器指向被删除元素的下一个元素。

vector<int> vec{1,2,3,4};
auto iter = vec.begin();
for(;iter!=vec.end();){
    if(true){
        iter = vec.erase(iter);
    }
} // 返回的vector为空

这里我们可能就想问,vector是否支持??vec.erase(iter++)??,需要注意,这种写法对vector、deque等容器无效!

7.2、增加元素

在下面vec的每个元素前插入数字8

vector<int> vec{1,2,3,4};
auto iter = vec.begin();
for(;iter!=vec.end();){
    iter = vec.insert(iter, 8);
    iter++;
    iter++;
} //8,1,8,2,8,3,8,4

相关推荐

为何越来越多的编程语言使用JSON(为什么编程)

JSON是JavascriptObjectNotation的缩写,意思是Javascript对象表示法,是一种易于人类阅读和对编程友好的文本数据传递方法,是JavaScript语言规范定义的一个子...

何时在数据库中使用 JSON(数据库用json格式存储)

在本文中,您将了解何时应考虑将JSON数据类型添加到表中以及何时应避免使用它们。每天?分享?最新?软件?开发?,Devops,敏捷?,测试?以及?项目?管理?最新?,最热门?的?文章?,每天?花?...

MySQL 从零开始:05 数据类型(mysql数据类型有哪些,并举例)

前面的讲解中已经接触到了表的创建,表的创建是对字段的声明,比如:上述语句声明了字段的名称、类型、所占空间、默认值和是否可以为空等信息。其中的int、varchar、char和decimal都...

JSON对象花样进阶(json格式对象)

一、引言在现代Web开发中,JSON(JavaScriptObjectNotation)已经成为数据交换的标准格式。无论是从前端向后端发送数据,还是从后端接收数据,JSON都是不可或缺的一部分。...

深入理解 JSON 和 Form-data(json和formdata提交区别)

在讨论现代网络开发与API设计的语境下,理解客户端和服务器间如何有效且可靠地交换数据变得尤为关键。这里,特别值得关注的是两种主流数据格式:...

JSON 语法(json 语法 priority)

JSON语法是JavaScript语法的子集。JSON语法规则JSON语法是JavaScript对象表示法语法的子集。数据在名称/值对中数据由逗号分隔花括号保存对象方括号保存数组JS...

JSON语法详解(json的语法规则)

JSON语法规则JSON语法是JavaScript对象表示法语法的子集。数据在名称/值对中数据由逗号分隔大括号保存对象中括号保存数组注意:json的key是字符串,且必须是双引号,不能是单引号...

MySQL JSON数据类型操作(mysql的json)

概述mysql自5.7.8版本开始,就支持了json结构的数据存储和查询,这表明了mysql也在不断的学习和增加nosql数据库的有点。但mysql毕竟是关系型数据库,在处理json这种非结构化的数据...

JSON的数据模式(json数据格式示例)

像XML模式一样,JSON数据格式也有Schema,这是一个基于JSON格式的规范。JSON模式也以JSON格式编写。它用于验证JSON数据。JSON模式示例以下代码显示了基本的JSON模式。{"...

前端学习——JSON格式详解(后端json格式)

JSON(JavaScriptObjectNotation)是一种轻量级的数据交换格式。易于人阅读和编写。同时也易于机器解析和生成。它基于JavaScriptProgrammingLa...

什么是 JSON:详解 JSON 及其优势(什么叫json)

现在程序员还有谁不知道JSON吗?无论对于前端还是后端,JSON都是一种常见的数据格式。那么JSON到底是什么呢?JSON的定义...

PostgreSQL JSON 类型:处理结构化数据

PostgreSQL提供JSON类型,以存储结构化数据。JSON是一种开放的数据格式,可用于存储各种类型的值。什么是JSON类型?JSON类型表示JSON(JavaScriptO...

JavaScript:JSON、三种包装类(javascript 包)

JOSN:我们希望可以将一个对象在不同的语言中进行传递,以达到通信的目的,最佳方式就是将一个对象转换为字符串的形式JSON(JavaScriptObjectNotation)-JS的对象表示法...

Python数据分析 只要1分钟 教你玩转JSON 全程干货

Json简介:Json,全名JavaScriptObjectNotation,JSON(JavaScriptObjectNotation(记号、标记))是一种轻量级的数据交换格式。它基于J...

比较一下JSON与XML两种数据格式?(json和xml哪个好)

JSON(JavaScriptObjectNotation)和XML(eXtensibleMarkupLanguage)是在日常开发中比较常用的两种数据格式,它们主要的作用就是用来进行数据的传...

取消回复欢迎 发表评论:

请填写验证码