当前位置: 首页 > article >正文

C++学习 --vector

目录

1, 什么是vector

2, 创建vector

2-1, 标准数据类型

2-2, 自定义数据类型

2-3, 其他创建方式

3, 操作vector

3-1, 赋值

3-2, 添加元素

 3-2-1, 添加元素(assign)

3-2-1-1, 标准数据类型

3-2-1-2, 自定义数据类型

3-2-2, 添加元素(insert)

3-2-2-1, 标准数据类型

3-2-2-2, 自定义数据类型

3-2-3, 添加元素(push_back)

3-2-3-1, 标准数据类型

3-2-3-2, 自定义数据类型

3-3, 查询(at)

3-3-1, 标准数据类型

3-3-2, 自定义数据类型

3-4, 获取容量(capacity)

3-5, 获取长度(size)

3-6, 交换(swap)

3-7, 删除元素(erase)

3-8, 清空元素(clear)

4, 嵌套vector


1, 什么是vector

C++中的一种容器数据类型, 也叫单端数组, 动态扩展, 并不是在原空间上进行扩展,而是重新找更合适的内存空间, 将原来的数据拷贝到新空间,并释放原来的空间, 迭代器支持随机访问

2, 创建vector

通过vector<数据类型> 对象名, 可创建vector, 数据类型可以是标准数据类型, 也可以是自定义类型

2-1, 标准数据类型

//指定容器中元素数据类型为string
vector<string> v1;

2-2, 自定义数据类型

class Myclass
{
public:
	Myclass() {};
	Myclass(string name, int age) :m_name(name), m_age(age) {};
	string m_name;
	int m_age;
};

Myclass m("aaa", 1);
//容器中元素的类型为Myclass
vector<Myclass> v1;

2-3, 其他创建方式

Myclass m("aaa", 1);
vector<Myclass> v1;
//拷贝构造方式创建
vector<Myclass> v2(v1);
//通过迭代器容器方式创建
vector<Myclass> v3(v1.begin(), v1.end());
//创建v4, 并插入5个m对象
vector<Myclass> v4(5, m);

3, 操作vector

3-1, 赋值

通过vector<数据类型> 对象名2 = 对象名1, 进行赋值

vector<Myclass> v1;
vector<Myclass> v2 = v1;

3-2, 添加元素

 3-2-1, 添加元素(assign)

assign是用新的元素替换原来vector的元素

3-2-1-1, 标准数据类型
//通过迭代器区间方式进行赋值
v2.assign(v1.begin(), v1.end());
//给容器v1, 赋值5个字符串a
v1.assign(5, "a");
3-2-1-2, 自定义数据类型
//通过迭代器区间方式进行赋值
v2.assign(v1.begin(), v1.end());

Myclass m("aaa", 1);
//容器中元素的类型为Myclass
vector<Myclass> v1;
//给容器v1, 赋值5个m对象
v1.assign(5, m);

3-2-2, 添加元素(insert)

insert是向vector指定位置, 添加元素, 支持一次添加多个元素

3-2-2-1, 标准数据类型
//表示在首元素位置, 以此插入3个字符串b
v1.insert(v1.begin(), 3, "b");
//表示在首元素位置, 插入字符串c
v1.insert(v1.begin(), "c");
3-2-2-2, 自定义数据类型
Myclass m1("aaa", 1);
vector<Myclass> v1;
//在首元素处插入m1
v1.insert(v1.begin(), m1);
//在首元素处插入2个m1
v1.insert(v1.begin(), 2, m1);

3-2-3, 添加元素(push_back)

push_back是在vector的尾部添加元素, 只能单个添加

3-2-3-1, 标准数据类型
vector<string> v1;
v1.assign(3, "a");
//在尾部添加c
v1.push_back("c");
3-2-3-2, 自定义数据类型
Myclass m1("aaa", 1);
Myclass m2("bbb", 2);
vector<Myclass> v1;
v1.assign(3, m1);
//在尾部添加m2
v1.push_back(m2);

3-3, 查询(at)

通过对象名[索引]或者对象名.at(索引), 获取vector中的元素

3-3-1, 标准数据类型

//通过索引方式查询
cout << v1[0] << endl;
//通过at方式查询
cout << v1.at(1) << endl;
//获取首元素
cout << v1.front() << endl;
//获取尾元素
cout << v1.back() << endl;

3-3-2, 自定义数据类型

Myclass m1("aaa", 1);
Myclass m2("bbb", 2);
Myclass m3("ccc", 3);
vector<Myclass> v1;
v1.push_back(m1);
v1.push_back(m2);
v1.push_back(m3);

//通过索引方式查询
cout << v1[0].m_name << endl;
//通过at方式查询
cout << v1.at(1).m_name << endl;
//获取首元素
cout << v1.front().m_name << endl;
//获取尾元素
cout << v1.back().m_name << endl;

3-4, 获取容量(capacity)

通过对象名.capacity(), 获取vector的容量大小

cout << v1.capacity() << endl;

3-5, 获取长度(size)

通过对象名.size(), 获取vector的元素个数

cout << v1.size() << endl;

3-6, 交换(swap)

通过对象名1.size(对象名2) 交换两个vector的元素, 两个vector的数据类型需要一致

v1.swap(v2);

3-7, 删除元素(erase)

通过对象名.erase(迭代器位置), 删除元素

//指定迭代器位置删除元素
v1.erase(v1.begin());
//删除尾部元素
v1.pop_back();

3-8, 清空元素(clear)

通过对象名.clear(), 清空vector元素

v1.clear();
//指定迭代器区间清空元素
v1.erase(v1.begin(), v1.end());

4, 嵌套vector

通过vector<vector<数据类型>> 对象名, 可实现嵌套vector

#include <iostream>
#include <string>
#include <vector>

using namespace std;

class Myclass
{
public:
	Myclass() {};
	Myclass(string name, int age) :m_name(name), m_age(age) {};
	string m_name;
	int m_age;
};

void print_v(vector<vector<Myclass>>& v)
{
	//it为外层vector的第一个元素迭代器
	for (vector<vector<Myclass>>::iterator it = v.begin(); it != v.end(); it++)
	{
		//vit为内层vector的第一个元素迭代器
		for (vector<Myclass>::iterator vit = (*it).begin(); vit != (*it).end(); vit++)
		{
			cout << vit->m_name << endl;
		}
	}
}

int main()
{
	Myclass m1("aaa", 1);
	vector<Myclass> v1;
	vector<vector<Myclass>> v2;
	v1.push_back(m1);
	v2.push_back(v1);

	print_v(v2);

	system("pause");

	return 0;
}


http://www.kler.cn/news/134030.html

相关文章:

  • Linux 零拷贝splice函数
  • 【C++】入门三
  • DeepMind发布新模型Mirasol3B:更高效处理音频、视频数据
  • 竞赛选题 深度学习花卉识别 - python 机器视觉 opencv
  • ExoPlayer架构详解与源码分析(9)——TsExtractor
  • 【Synopsys Bug记录】DC综合报错(显示warning:Unable to resolve reference)
  • DrugMAP: molecular atlas and pharma-information of all drugs学习
  • transform学习资料
  • LLM大模型4位量化实战【GPTQ】
  • Linux 配置RealVNC远程访问
  • 中国制库:创新引领,效率突破,塑造行业新标准
  • redis三种集群方式
  • 21、嵌套路由实战操作
  • Smart Tomcat的使用
  • FastJsonAPI
  • 系列二十六、idea安装javap -c
  • Linux服务器挂载另一台服务器的文件夹(mount)
  • 力扣刷题篇之位运算
  • 力扣83. 删除排序链表中的重复元素(java常规解法 + 建立虚拟头节点)
  • springBoot 配置druid多数据源 MySQL+SQLSERVER
  • sqli-labs关卡20(基于http头部报错盲注)通关思路
  • vite vue3安装element-plus
  • 【开源】基于Vue.js的开放实验室管理系统的设计和实现
  • 【Java 进阶篇】Ajax 入门:打开前端异步交互的大门
  • 【Kingbase FlySync】命令模式:部署双轨并行,并实现切换同步
  • Git 简介及使用
  • 手机,蓝牙开发板,TTL/USB模块,电脑四者之间的通讯
  • mybatis使用xml形式配置
  • c# 设计一个图书管理系统
  • react 手机端 rc-table列隐藏(根据相关条件是否隐藏)、实现图片上传操作