浅谈vector

简介

std::vector (向量): C++中的一种数据结构, 是封装动态数组的序列容器。内部元素是连续存储的, 可以通过迭代器和下标访问元素。

用法

  • 包含头文件 #include <vector> 需要添加 using namespace std; 如:
#include <iostream>
#include <vector>
using namespace std;
int main()
{
    vector<int> num;
    .....
}

如要在.hpp中定义可以:

...
#include <vector>
...
std::vector<int> num;
...
  • 变量声明
    容器中可以储存任意类型的数据,如:
// 常用类型 构成相应的数组
vector<int> n; 
vector<string> s;
// 也可以是自定义类型 类
vector<class> cl; 
...
  • 常用功能
方法 简介
clear() 移除容器中所有数据。
empty() 判断容器是否为空。
erase(pos) 删除pos位置的数据
erase(beg,end) 删除[beg,end)区间的数据
front() 传回第一个数据。
insert(pos, elem) 在pos位置插入一个elem拷贝
pop_back() 删除最后一个数据。
push_back(elem) 在尾部加入一个数据。
resize(num) 重新设置该容器的大小
size() 回容器中实际数据的个数。
begin() 返回指向容器第一个元素的迭代器
end() 返回指向容器最后一个元素的迭代器
  • 遍历方法
  1. 通过迭代器遍历
#include <iostream>
#include <vector>
using namespace std;
int main()
{
        vector<int> num;
        for(int i = 0; i < 10; i++)
        {
            num.push_back(i);
        }
        for(vector<int>::iterator it = num.begin(); it < num.end(); it++)
        { 
             cout << *it << endl;
        }
}
  1. 通过下标遍历 和数组类似
#include <iostream>
#include <vector>
using namespace std;
int main()
{
        vector<int> num;
        for(int i = 0; i < 10; i++)
        {
            num.push_back(i);
        }
        for(size_t i = 0; i < num.size(); i++)
        {
             cout << num[i] << endl;
        }
}

结语

该数据结构相当于一个动态的数组,当程序员无法知道自己需要的数组的规模多大时,用其来解决问题可以达到最大节约空间的目的。
详细内容见 api 文档

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容