vector

Vector

1.支持随机访问迭代器,所有STL算法都能对vector操作。

2.随机访问时间为常数。在尾部添加速度很快,在中间插入慢。实际上就是动态数组。

 

头文件                    #include<vector>

  定义变量                vector<int>myvec;

  主要成员函数

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

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

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

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

   myvec.erase(pos)              删除pos位置的数据, 返回下一个数据的位置。

 myvec.insert(pos,cnt,elem)  pos位置插入cnt个数据elem

    myvec.begin()                   返回的指针指向数组中的第一个数据。

    myvec.end()          实际上是取末尾加一,以便让循环正确运行--它返回的指针指向最靠近数组界限的数据。

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

  operator[]                         返回容器中指定位置的一个引用


具体应用:


#include<iostream>
#include<vector>
using namespace std;
int main()
{
    vector<int >vec1;//vec1对象初始化为空
    vector<int>vec2(10,2);//初始化10个数为2
    vector<int>vec3(vec2.begin(),vec2.begin()+3);//初始化为3个2
    vector<int>::iterator it;//声明双向迭代器
    cout<<"vec1:"<<endl;
    for(it=vec1.begin();it!=vec1.end();it++)
        cout<<*it<<" ";
        cout<<endl;
    cout<<"vec2:"<<endl;
    for(it=vec2.begin();it!=vec2.end();it++)
        cout<<*it<<" ";
        cout<<endl;
    cout<<"vec3:"<<endl;
    for(it=vec3.begin();it!=vec3.end();it++)
        cout<<*it<<" ";
        cout<<endl;
    vec1.push_back(2);//从末尾添加成员
    vec1.push_back(6);
    vec1.insert(vec1.begin()+1,5);//在vec1第一个位置插入成员5
    vec1.insert(vec1.begin()+1,vec3.begin(),vec3.end());//在vec1第一个位置插入vec3的全部成员
    cout<<"vec1:"<<endl;
    for(it=vec1.begin();it!=vec1.end();it++)
        cout<<*it<<" ";
        cout<<endl;
    vec2.assign(8,1);//重新给vec2赋值
    cout<<"vec2:"<<endl;
    for(it=vec2.begin();it!=vec2.end();it++)
        cout<<*it<<" ";
        cout<<endl;
    //引用类函数
    cout<<"vec1.front()="<<vec1.front()<<endl;//vec1第0成员
    cout<<"vec1.back()="<<vec1.back()<<endl;//vec1最后成员
    cout<<"vec1.at(4)="<<vec1.at(4)<<endl;//vec1第五成员
    //测试移除和删除
    vec1.pop_back();//最后一个删除
    vec1.erase(vec1.begin(),vec1.end()-2);//删除成员
    cout<<"vec1:"<<endl;
    for(it=vec1.begin();it!=vec1.end();it++)
        cout<<*it<<" ";
        cout<<endl;
    //显示序列的信息
    cout<<"vec1.size()="<<vec1.size()<<endl;//打印成员个数
    cout<<"vec1.empty()="<<vec1.empty()<<endl;//是否为空
    return 0;
}


评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值