zoukankan      html  css  js  c++  java
  • STL迭代器之向量

    当使用输入迭代器的时候,也就是直接用迭代器(指针)输入的时候一定要指定容器的大小,否则在运行时出错。可能是不指定大小就不好分配地址,就会出错吧。这都是我自己的一些猜想,很可能是错的,或不严谨。

    但是在使用容器的成员函数进行写入、插入时就可以不指定向量容器大小。例如iVect.push_back(520)。

    #include<iostream>
    #include<vector> //包含STL向量模板头文件
    #include<algorithm> //包含STL算法头文件
    using namespace std;
    //如果不声明命名std空间那么endl就必须写成std::endl;
    //向量的定义就是std::vector<int> iVector;这就是命名空间的作用

    void Display(int val)
    {
    cout<<val<<'\t';
    }
    int main()
    {
    vector<int> iVect(4); //当不指定向量的大小的,会在运行时出错
    vector<int>::iterator it = iVect.begin();
    *it++ = 5;
    *it++ = 2;
    *it++ = 0;
    *it = 1314;
    for_each(iVect.begin(), iVect.end(), Display); //这是STL算法中的一个函数相当于一个循环语句
    return 0;

    }

    #include<iostream>
    #include<vector> //包含STL向量模板头文件
    #include<algorithm> //包含STL算法头文件
    using namespace std;
    //如果不声明命名std空间那么endl就必须写成std::endl;
    //向量的定义就是std::vector<int> iVector;这就是命名空间的作用

    void Display(int val)
    {
    cout<<val<<'\t';
    }
    int main()
    {
    vector<int> iVect(4); //当不指定向量的大小的,会在运行时出错
    iVect[0] = 5;
    iVect[1] = 2;
    iVect[2] = 0;
    iVect[3] = 1314;

    for_each(iVect.begin(), iVect.end(), Display); //这是STL算法中的一个函数相当于一个循环语句
    return 0;
    }

  • 相关阅读:
    【递推】BZOJ 4300:绝世好题
    【概率DP/高斯消元】BZOJ 2337:[HNOI2011]XOR和路径
    【DP】permu
    【LCA】CodeForce #326 Div.2 E:Duff in the Army
    论本人为什么不更博
    [洛谷P6640] BJOI2020 封印
    [洛谷P5320] BJOI2019 勘破神机
    [AGC003E] Sequential operations on Sequence
    [CF407C] Curious Array
    [LOJ2759] JOI2014 Final 飞天鼠
  • 原文地址:https://www.cnblogs.com/emptyYPen/p/5928322.html
Copyright © 2011-2022 走看看