C++基础知识--初识Vector容器

C++之STL基础知识--初识vector
我们之前学习过静态数组的内容,静态数组的缺点在于一旦初始化之后,数组大小便无法改变,但是动态数组不存在这个问题.动态数组(vector容器)在需要扩展大小的时候,会自动处理它自己的存储需求.也就是说vector容器会根据添加的元素自动调正自身的大小.
要使用vector容器,需要声明头文件#include<vector>
vector使用格式vector<typename> variable

#include <iostream>
#include <vector>

using namespace std;

int main() {

    vector<int> vec;
    int i = 0;
    cout << "vector_size:" << vec.size() << endl;
    for (i; i < 6; i++) {
        vec.push_back(i + 1);
    }
    cout << "vector_expand_num:" << vec.size() << endl;
    for (i; i >= 0; i--) {
        cout << "get_vec_value:" << vec[i] << endl;
    }
    
    for(vector<int>::iterator v = vec.begin(); v != vec.end(),v++) 
    {
        cout << "v_value:" << *v << endl;
    }
    return 0;
}
输出:
vector_size:0
vector_expand_num:6
get_vec_value:17367376
get_vec_value:6
get_vec_value:5
get_vec_value:4
get_vec_value:3
get_vec_value:2
get_vec_value:1
v_value:1
v_value:2
v_value:3
v_value:4
v_value:5
v_value:6

push_back():在容器尾部添加数据
vector.size():获取容器大小
vector.begin():指向容器头部的迭代器
vector.end():指向容器尾部的迭代器
再来看字符串的用法

#include <iostream>
#include <vector>

using namespace std;

int main() {
    vector<string> str;
    str.push_back("www");
    str.push_back(".baidu");
    str.push_back(".com");
    for (vector<string>::iterator iter = str.begin(); iter != str.end(); ++iter) {
        cout << *iter;
    }
    return 0;
}

函数                          介绍
at(idx)                     传回索引idx所指的数据,如果idx越界,抛出out_of_range。
back()                     返回最后一个元素,不检查这个数据是否存在。
front()                      返回第一个元素。
swap()                    交换两个Vector。
pop_back()            它从向量中删除最后一个元素。
empty()                   判断Vector是否为空(返回true时为空)
insert()                    它将在指定位置插入新元素。
erase()                    删除指定的元素。
resize()                  它修改向量的大小。
clear()                    它从向量中删除所有元素。
size()                     返回Vector元素数量的大小。

str.erase(str.begin() + 1);//删除下标为1的元素
str.insert(str.begin() + 2, "123");//在下标为2的位置插入元素
str.pop_back();//删除尾部的元素
str.resize(10);//改变容器的大小
str.at(0);//返回下标为0的元素
str.back();//返回尾部元素
str.front();//返回头部元素

猜你喜欢

转载自blog.csdn.net/weixin_50016546/article/details/131513773