首页 > 其他分享 >std::vector 的使用

std::vector 的使用

时间:2022-10-14 03:33:25浏览次数:42  
标签:std cout vertices back vector 使用 push include

std::vector 是物理存储空间连续、无需指定大小、自动扩容的动态数组,并提供了丰富的 API。

初练

  • 添加元素(末尾):push_back
  • 删除元素(末尾):pop_back
  • 获取元素个数:size
  • 遍历方法
 1 #include <iostream>
 2 #include <vector>
 3 
 4 int main()
 5 {
 6       std::vector<int> container;
 7       container.push_back(1);
 8       container.push_back(2);
 9       container.push_back(3);
10       container.push_back(4);
11       container.push_back(5);
12       for (int i = 0; i < container.size(); ++i) std::cout << 
13 container[i] << ' ';
14       std::cout << std::endl;
15 
16       container.pop_back();
17       container.pop_back();
18       for (auto& e : container) std::cout << e << ' ';
19       std::cout << std::endl;
20 }

新手

  • 删除某一索引或某一范围的元素(传入其迭代器):erase
  • 删除所有元素:clear
  • 适用自定义类型
  • 引用传递避免直接拷贝
 1 #include <iostream>
 2 #include <vector>
 3 
 4 struct Vertex
 5 {
 6       float x, y, z;
 7 };
 8 
 9 std::ostream& operator<<(std::ostream& stream, const Vertex& vertex)
10 {
11       stream << vertex.x << ", " << vertex.y << ", " << vertex.z;
12       return stream;
13 }
14 
15 void Print(const std::vector<Vertex>& vertices)
16 {
17       std::cout << "----------------------------------------" <<
18             std::endl;
19       for (auto& v : vertices) std::cout << v << std::endl;
20       std::cout << "----------------------------------------" <<
21             std::endl;
22 }
23 
24 int main()
25 {
26       std::vector<Vertex> vertices;
27       vertices.push_back({ 1, 2, 3 });
28       vertices.push_back({ 4, 5, 6 });
29       vertices.push_back({ 7, 8, 9 });
30       vertices.push_back({ 10, 11, 12 });
31       vertices.push_back({ 13, 14, 15 });
32       vertices.push_back({ 16, 17, 18 });
33 
34       Print(vertices);
35       vertices.erase(vertices.begin() + 1);  // Delete index 1
36       Print(vertices);
37       vertices.erase(vertices.begin() + 2, vertices.end() - 1);  // 
38 Delete index 2, 3
39       Print(vertices);
40       vertices.clear();  // No any element
41       Print(vertices);
42 }
  • 分配的内存容量、物理容量(动态扩充):capacity
  • 指定分配的内存容量大小:reserve
  • 就地创建并添加元素:emplace_back
  • 两种避免多余元素拷贝的方法
 1 #include <iostream>
 2 #include <vector>
 3 
 4 struct Vertex
 5 {
 6       float x, y, z;
 7 
 8       Vertex(float x, float y, float z)
 9             : x(x), y(y), z(z)
10       {
11       }
12 
13       Vertex(const Vertex& vertex)
14             : x(vertex.x), y(vertex.y), z(vertex.z)
15       {
16             std::cout << "Copied!" << std::endl;
17       }
18 };
19 
20 void PrintCapacity(const std::vector<Vertex>& vertices)
21 {
22       std::cout << vertices.capacity() << std::endl;
23 }
24 
25 int main()
26 {
27       // The code that can be optimized.
28       std::cout << "----------------------------------------" << 
29 std::endl;
30       {
31             std::vector<Vertex> vertices;
32             vertices.push_back({ 1, 2, 3 });
33             PrintCapacity(vertices);
34             vertices.push_back({ 4, 5, 6 });
35             PrintCapacity(vertices);
36             vertices.push_back({ 7, 8, 9 });
37             PrintCapacity(vertices);
38       }
39       
40       // Method 1: use reserve to avoid resizing capacity to decrease 
41 copies.
42       std::cout << "----------------------------------------" << 
43 std::endl;
44       {
45             std::vector<Vertex> vertices;
46             vertices.reserve(3);
47             PrintCapacity(vertices);
48             vertices.push_back({ 1, 2, 3 });
49             vertices.push_back({ 4, 5, 6 });
50             vertices.push_back({ 7, 8, 9 });
51             PrintCapacity(vertices);
52       }
53       
54       // Method 2: use emplace_back to efficiently construct element 
55 inside the vector container.
56       std::cout << "----------------------------------------" << 
57 std::endl;
58       {
59             std::vector<Vertex> vertices;
60             vertices.reserve(3);
61             vertices.emplace_back(1, 2, 3);
62             vertices.emplace_back(4, 5, 6);
63             vertices.emplace_back(7, 8, 9);
64       }
65 
66       std::cout << "----------------------------------------" << 
67 std::endl;
68 }

中级

  • 获取第一个元素的引用:front
  • 获取最后一个元素的引用:back
  • 获取第一个元素的指针:data
  • 修改 size:resize
 1 #include <iostream>
 2 #include <vector>
 3 
 4 int main()
 5 {
 6       std::vector<int> v;
 7       v.push_back(1);
 8       v.push_back(2);
 9       v.push_back(3);
10 
11       std::cout << "------------front/back------------" << std::endl;
12       std::cout << v.front() << std::endl;
13       v.front() = 100;  // this will change v[0]
14       std::cout << v[0] << std::endl;
15       std::cout << v.back() << std::endl;
16 
17       std::cout << "------------data------------" << std::endl;
18       int* p = v.data();
19       std::cout << (&(v.front()) == p) << std::endl;  // 1
20       std::cout << *p << std::endl;
21       std::cout << p[1] << std::endl;
22 
23       std::cout << "------------resize------------" << std::endl;
24       for (auto& e : v) std::cout << e << " ";
25       std::cout << std::endl;
26       v.resize(5, -1);
27       for (auto& e : v) std::cout << e << " ";
28       std::cout << std::endl;
29       std::cout << "size=" << v.size() << " capacity=" << v.capacity() 
30 << std::endl;  // both increase
31 }
  • 释放不必要的空间:shrink_to_fit
 1 #include <iostream>
 2 #include <vector>
 3 
 4 int main()
 5 {
 6       std::vector<int> v;
 7       for (int i = 0; i < 100000; ++i) v.push_back(i);
 8       v.resize(3);
 9 
10       std::cout << "size=" << v.size() << std::endl;
11       std::cout << "capacity=" << v.capacity() << std::endl;
12       std::cout << "-----------------------------------------" << 
13 std::endl;
14 
15       v.shrink_to_fit();
16       std::cout << "size=" << v.size() << std::endl;
17       std::cout << "capacity=" << v.capacity() << std::endl;
18 }
  • 插入元素:insert
 1 #include <iostream>
 2 #include <vector>
 3 
 4 void Print(const std::vector<int>& v)
 5 {
 6       for (auto& e : v) std::cout << e << " ";
 7       std::cout << std::endl;
 8 }
 9 
10 int main()
11 {
12       std::vector<int> v;
13       v.emplace_back(1);
14       v.emplace_back(2);
15       v.emplace_back(3);
16       Print(v);
17 
18       std::cout << "------------insert(v.begin(), 100)------------" << 
19 std::endl;
20       v.insert(v.begin(), 100);  // insert at index 0
21       Print(v);
22 
23       std::cout << "------------insert(v.begin(), 2, 1000)------------" 
24 << std::endl;
25       v.insert(v.begin(), 2, 1000);  // insert 2 items at index 0
26       Print(v);
27 
28       std::cout << "------------insert(std::next(v.begin(), 3), 
29 other.begin(), other.end())------------" << std::endl;
30       std::vector<int> other(2, 666);
31       v.insert(std::next(v.begin(), 3), other.begin(), other.end());  // 
32 insert a range at index 3
33       Print(v);
34 
35       std::cout << "------------insert(v.begin(), arr, arr + 
36 std::size(arr))------------" << std::endl;
37       int arr[3] = { 888, 888, 888 };
38       v.insert(v.begin(), arr, arr + std::size(arr));  // insert a array 
39 at index 0
40       Print(v);
41 
42       std::cout << "------------insert(v.end(), { 999, 999 
43 })------------" << std::endl;
44       v.insert(v.end(), { 999, 999 });  // insert literals
45       Print(v);
46 }

高级 or 骨灰级

Life is short. keep it simple.  

 

 

 

 

 

 

标签:std,cout,vertices,back,vector,使用,push,include
From: https://www.cnblogs.com/noluye/p/16790259.html

相关文章

  • C#事务的使用
    https://blog.csdn.net/VisageNocturne/article/details/112094795http://t.zoukankan.com/SmilePastaLi-p-6824387.htmlhttps://www.w3xue.com/exp/article/20225/79298......
  • IIS 绿盟检测到HOST头攻击漏洞的解决: web应用使用SERVER_NAME而非host header。
    https://blog.csdn.net/fightingintherain/article/details/1256648851、漏洞描述2、修复方案(IIS服务端) 1)下载安装url重写工具(官网URLRewrite:TheOfficialMic......
  • SharedWorker使用总结
    最近有个需求要在浏览器页签之间实现信息共享,由第三方包处理。看过人家的效果介绍,嚯哦,闪瞎我的双眼!没见识过的技术,怎么也得看一看呀......
  • moment使用方法
    引入:<scriptsrc="https://cdn.bootcdn.net/ajax/libs/moment.js/2.29.4/locale/af.js"></script>格式化期moment().format('MMMMDoYYYY,h:mm:ssa');//三月3日......
  • Echart使用
    EChart目录目录EChart官网导入大体架构视图大小官网https://echarts.apache.org/zh/index.html导入<scriptsrc="https://cdn.bootcdn.net/ajax/libs/echarts/5.3......
  • Containerd-1.6.5 命令空间和task使用
    一、命令空间每个顶级配置块的命名都是plugin."io.containerd.xxx.xxx.xxx"这种形式,其实每个顶级配置块都代表一个插件。其中io.containerd.xxx.xxx表示插件类型,xxx后面......
  • 实验一 C语言开发环境使用和编程初体验
    实验任务一//实验任务一#include<stdio.h>intmain(){printf("O\n");printf("<H>\n");printf("II\n");return0;}task1_1.c//实验任......
  • 使用 Vue-cli 脚手架创建项目
    本次以WIN10系统为例,其他系统略有差异。第一步,安装npm:进入Node.js官网下载左侧稳定版,因为node包含npm由于node包含npm,所以我们只需要安装node就好了。进入Node.js官网首......
  • Oracle PDB的相关使用说明
    OraclePDB的相关使用说明摘要PDBpluggabledatabase是Oracle12c以上的版本(Oracle18c.oracle19c)新增加的一个特性.他可以实现灵活插拔的方式进行PDB的创建于使......
  • 解决 vue 项目使用 swiper 遇到设置轮播图自动播放不生效问题
    前言项目使用到swiper插件实现轮播图的功能,引入插件放上数据后,设置自动播放,但是发现没起效果,手动拖动可以解决方法安装指定版本可以安装以下版本的,设置自动播放没有......