vector用法

目录

vector底层数据结构:

方法:

增加:

删除:

查询:


vector底层数据结构:

动态开辟的数组,通过三个指针_first、_last、_end维护

  • _first指向动态数组的首地址
  • _last指向最后一个有效元素的尾后
  • _end指向动态数组最后一个位置的尾后

size为容器的有效元素,size=_last - _first

_end - _first 为容器当前的最大容量

方法:

增加:

  • push_back(val),尾插,O(1),容量不够时会扩容
  • insert(it,val),在it迭代器指向的位置添加元素,O(n),容量不够时会扩容,返回值为指向该位置的迭代器

删除:

  • pop_back(),尾删,O(1)
  • erase(it),删除迭代器指向位置的元素,O(n),返回值为指向该位置的迭代器

查询:

operator[] , 下标的随机访问 ,O(1)

iterator 迭代器遍历容器

foreach语法糖(通过iterator实现)

注:

对容器进行连续的插入或删除(insert/erase)时,一定要更新迭代器,否则第一次操作后,迭代器就失效了!

常用方法:

size() , empty()
reserve(int); 预留空间,只开空间,不添元素
resize(int); 扩容,即开空间,也添元素

swap() ,两容器进行元素交换

代码练习:

cpp 复制代码
#include<iostream>
#include<vector>
using namespace std;

int main()
{
	vector<int> vec;

	vec.reserve(20);
	for (int i = 0; i < 20; i++)
	{
		vec.push_back(rand() % 100);
	}
	for (int i = 0; i < 20; i++)
	{
		cout << vec[i] << " ";
	}
	cout << endl;

	auto it1 = vec.begin();

	while (it1 != vec.end())
	{
		if (*it1 % 2 == 0)
		{
			it1 = vec.erase(it1);
		}
		else
		{
			it1++;
		}
	}

	for (it1=vec.begin(); it1 != vec.end(); it1++)
	{
		cout << *it1 << " ";
	}
	cout << endl;

	int size = vec.size();
	for (it1=vec.begin();it1!=vec.end();it1++)
	{
		if (*it1 % 2 != 0)
		{
			it1 = vec.insert(it1, *it1 - 1);
			it1++;
		}
	}

	for (auto x : vec)
	{
		cout << x << " ";
	}
	cout << endl;
	vector<int> tmp(12);
	for (auto& x : tmp)
	{
		x = 12;
	}
	for (auto& x : tmp)
	{
		cout << x << " ";
	}
	swap(vec, tmp);
	cout << endl;
	for (auto& x : tmp)
	{
		cout << x << " ";
	}
	return 0;
}
相关推荐
鸽芷咕16 分钟前
【Python报错已解决】ModuleNotFoundError: No module named ‘paddle‘
开发语言·python·机器学习·bug·paddle
Jhxbdks25 分钟前
C语言中的一些小知识(二)
c语言·开发语言·笔记
java66666888825 分钟前
如何在Java中实现高效的对象映射:Dozer与MapStruct的比较与优化
java·开发语言
Violet永存26 分钟前
源码分析:LinkedList
java·开发语言
代码雕刻家28 分钟前
数据结构-3.1.栈的基本概念
c语言·开发语言·数据结构
Fan_web29 分钟前
JavaScript高级——闭包应用-自定义js模块
开发语言·前端·javascript·css·html
梦想科研社34 分钟前
【无人机设计与控制】四旋翼无人机俯仰姿态保持模糊PID控制(带说明报告)
开发语言·算法·数学建模·matlab·无人机
风等雨归期35 分钟前
【python】【绘制小程序】动态爱心绘制
开发语言·python·小程序
千穹凌帝38 分钟前
SpinalHDL之结构(二)
开发语言·前端·fpga开发
AlexMercer101240 分钟前
【C++】二、数据类型 (同C)
c语言·开发语言·数据结构·c++·笔记·算法