美文网首页C++
浅谈vector

浅谈vector

作者: 咻咻咻i | 来源:发表于2017-06-06 15:40 被阅读0次

简介

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 文档

相关文章

  • 浅谈Vector

    Vector结构图 Vector主要方法 public synchronized boolean add(E e)...

  • 浅谈vector

    简介 std::vector (向量): C++中的一种数据结构, 是封装动态数组的序列容器。内部元素是连续存储的...

  • c++常用数据结构

    问题:vector与数组的区别? 1、vector vector v;//创建vector v....

  • 浅谈java中的Vector,ArrayList,LinkedL

    第一,简介 这三者都是实现集合框架中的List,也就是所谓的有序集合,因此具体功能也比较近似,比如都提供按照位置进...

  • 指针

    ①动态指针问题. vector * pvt = new vector [100]; vector * tt; tt...

  • 2021-12-01 opencv findContours a

    std::vector contours; std::vector hi...

  • 13.C++ vector 操作

    vector初始化 vector大小 数组方式操作vector 迭代器方式操作vector 反向迭代器操作vect...

  • c++零散知识

    1、vector vector对象内存增长原理,当向vector添加新元素而vector没有足够的内存保存新元素时...

  • vector

    一、vector介绍:可边长数组1、vector的定义:vector name;注:vecto...

  • Collection-Vector

    jdk版本:1.8.0_77参考文档:jdk 1.8 docs Vector类图 Vector特点 Vector对...

网友评论

    本文标题:浅谈vector

    本文链接:https://www.haomeiwen.com/subject/vvggfxtx.html