zoukankan      html  css  js  c++  java
  • vector

    头文件

    首先要引入头文件 #include <vector>  并使用命名空间:using namespace std;

    1、vector的创建

        vector<int> vec1; // 创建一个空的vector
        vector<int> vec2(vec1); // 创建一个vector vec2,并用vec1去初始化vec2
        vector<int> vec3(10); // 创建一个含有n个数据的vector
        vector<int> vec4(10,0); // 创建含有10个数据的vector,并全部初始化为0
    

    2、push_back(),pop_back()添加删除元素

        // 在vector尾部添加元素
        vec1.push_back(4);
        vec1.push_back(6);
        vec1.push_back(8);
        vec1.push_back(1);
        vec1.push_back(2);
        PrintVector(vec1);
    
        // 在vector尾部删除元素
        vec1.pop_back();
        PrintVector(vec1);
    
        // 在vector头部添加元素,无法完成,因为vector的数据结构为数组,无法在头部插入元素,否则需要整个数组前移;
    
        // 在vector头部删除元素,无法完成,理由同上。
    

    3、[],at(),取某位置的元素值

    // 取vector中某位置的元素值
        cout << "在1位置的元素值为:" << vec1.at(1) << endl;
        cout << "在1位置的元素值为:" << vec1[1] << endl;
    

    4、begin(),end(),指向头元素、尾元素的指针

    void PrintVector(vector<int> ve)
    {
        cout << "Vector中的数据为:";
        vector<int>::iterator veIterator;
        for (veIterator = ve.begin(); veIterator < ve.end(); veIterator++)
        {
            cout << *veIterator << " ";
        }
        cout << endl;
    }
    

    5、back(),front(),访问头部元素和尾部元素

        // 返回尾部数据的引用
        cout << "尾部数据的值为:" << vec1.back() << endl;
        // 返回头部数据的引用
        cout << "头部数据的值为:" << vec1.front() << endl;
    

    6、max_size(),vector的最大容纳量;size():vector当前的元素个数

        cout << "vector中的最大容量为:" << vec1.max_size() << endl;
        cout << "vector中的元素个数为:" << vec1.size() << endl;
    

    7、empty(),判断vector是否为空(返回1:空  0: 非空)

    cout << "vector是否为空:" << vec1.empty() << endl;
    

    8、swap():交换两个vector中的值

    9、sort():对vector升序排序;reverse():对vector降序排序

    // 对vector进行升序排序
        sort(vec1.begin(), vec1.end());
        PrintVector(vec1);
    
        // 对vector进行降序排序
        reverse(vec1.begin(), vec1.end());
        PrintVector(vec1);
    

    10、[],at():修改元素

        // 修改vector中的某个值
        vec1[2] = 99;
        PrintVector(vec1);
    
        vec1.at(3) = 88;
        PrintVector(vec1);
    

    11、erase():删除某个元素

        // 删除数组的某个元素
        // 为什么要使用iterator来进行定位,因为数组如果要删除一个元素或者插入一个元素,会导致其他元素移动,所以不能直接进行删除
        vector<int>::iterator vItera = vec1.begin();
        vItera = vItera + 2;
        vec1.erase(vItera);
        PrintVector(vec1);

    12、insert(): 插入元素

        // vector插入某元素,要使用iterator来定位某个位置
        vector<int>::iterator vInsert = vec1.begin();
        vInsert = vInsert + 2;
        vec1.insert(vInsert, 777);
        PrintVector(vec1);
    

    13、clear():清除所有元素

     // 清除所有数据
        vec1.clear();
        PrintVector(vec1);
        cout << "vector是否为空:" << vec1.empty() << endl;
    
  • 相关阅读:
    JVM全面分析之程序计时器
    JVM全面分析之类加载系统
    问题
    -----------------------算法学习篇:斐波拉契数列------------------------
    -----------------------------------A Tour of C++ Chapter8-------------------------------------------
    -----------------Clean Code《代码整洁之道》--------------------
    -----------------------------------A Tour of C++-------------------------------------------
    -----------------Clean Code《代码整洁之道》--------------------
    http响应状态码大全
    DOM之通俗易懂讲解
  • 原文地址:https://www.cnblogs.com/cgc0415/p/8776797.html
Copyright © 2011-2022 走看看