• [STL][C++]VECTOR


     参考:http://blog.csdn.net/hancunai0017/article/details/7032383

    vector(向量): C++中的一种数据结构,确切的说是一个类.它相当于一个动态的数组,当程序员无法知道自己需要的数组的规模多大时,用其来解决问题可以达到最大节约空间的目的.

    vector头文件

    #include<vector>

    vector用法

     vector <int *> a

              int b = 5;

              a.push_back(b);//该函数下面有详解

              cout<<a[0];       //输出结果为5

    1.push_back   在数组的最后添加一个数据
    2.pop_back    去掉数组的最后一个数据 
    3.at                得到编号位置的数据
    4.begin           得到数组头的指针
    5.end             得到数组的最后一个单元+1的指针
    6.front        得到数组头的引用
    7.back            得到数组的最后一个单元的引用
    8.max_size     得到vector最大可以是多大
    9.capacity       当前vector分配的大小
    10.size           当前使用数据的大小
    11.resize         改变当前使用数据的大小,如果它比当前使用的大,者填充默认值
    12.reserve      改变当前vecotr所分配空间的大小
    13.erase         删除指针指向的数据项
    14.clear          清空当前的vector
    15.rbegin        将vector反转后的开始指针返回(其实就是原来的end-1)
    16.rend          将vector反转构的结束指针返回(其实就是原来的begin-1)
    17.empty        判断vector是否为空
    18.swap         与另一个vector交换数据

    实现

            其中vector<int> c.

                                 c.clear()         移除容器中所有数据。

                                 c.empty()         判断容器是否为空。

                                 c.erase(pos)        删除pos位置的数据

                                 c.erase(beg,end) 删除[beg,end)区间的数据

                                 c.front()         传回第一个数据。

                                 c.insert(pos,elem)  在pos位置插入一个elem拷贝

                                 c.pop_back()     删除最后一个数据。

                                 c.push_back(elem) 在尾部加入一个数据。

                                 c.resize(num)     重新设置该容器的大小

                                 c.size()         回容器中实际数据的个数。

                                 c.begin()           返回指向容器第一个元素的迭代器

                                 c.end()             返回指向容器最后一个元素的迭代器

    备注:在用vector的过程中的一些问题,特此列出讨论:

                   1)

                        vector <int > a;

                        int  b = 5;

                        a.push_back(b);

                        此时若对b另外赋值时不会影响a[0]的值

                    2)

                        vector <int*> a;
                         int *b;
                         b= new int[4];
                         b[0]=0;
                         b[1]=1;
                         b[2]=2;
                         a.push_back(b);
                         delete b;          //释放b的地址空间
                         for(int i=0 ; i <3 ; i++)
                         {
                               cout<<a[0][i]<<endl;
                         }

                         此时输出的值并不是一开始b数组初始化的值,而是一些无法预计的值.

                        分析:根据1) 2)的结果,可以想到,在1)中,  往a向量中压入的是b的值,即a[0]=b,此时a[0]和b是存储在两个不同的地址中的.因此改变b的值不会影响a[0];而在2)中,因为是把一个地址(指针)压入向量a,即a[0]=b,因此释放了b的地址也就释放了a[0]的地址,因此a[0]数组中存放的数值也就不得而知了.   

    补充:STL标准函数find进行vector 、list链表查找

    #include <vector>

    //注意find不属于vector的成员,而存在于算法中,应加上头文件#include <algorithm>:
    #include <algorithm>
    #include <iostream>

    class example
    {
    public:
    example(int val)
    {
    i = val;
    }

    bool operator==(example const & rhs)
    {
    return (i == rhs.i) ? true : false;
    }

    private:
    int i;
    };
    using namespace std;
    int main(void)
    {
    vector<example> ve;
    ve.push_back(1);
    vector<example>::iterator it;
    example elem(1);
    it = find(ve.begin(), ve.end(), elem);
    //cout<<boolalpha<<(*it == elem);

        if ( it == ve.end( ) ) //没找到
            cout << "No" << endl;
        else //找到
            cout << "Yes" << endl;
    }

  • 相关阅读:
    zigbee芯片
    笔记本ubuntu安装wifi驱动(未完成)
    我错了的N个学习
    《华为工作法》读书笔记
    bbblack的网络socket通信实验
    NB-IOT连接移动onenet平台流程
    移动onenet基础通信套件V1.08版本的AT指令测试
    CC3200使用MQTT的SSL加密证书可用日期修改
    利尔达NB-IOT模块烧写固件的步骤
    树莓派相机
  • 原文地址:https://www.cnblogs.com/lyggqm/p/4543762.html
Copyright © 2020-2023  润新知