STL 插入迭代器

目录

    在学习C++ Primer时,我们知道STL有3种插入迭代器,分别是:back_inserter,front_inserter,inserter 。

    • back_inserter:利用push_back在尾部插入元素;
    • front_inserter:利用push_front在头部插入元素;
    • inserter:利用insert在参数it指定位置插入元素;

    3者原型

    #include <iterator>
    
    template <class Container>
      back_insert_iterator<Container> back_inserter (Container& x);
    
    template <class Container>
      front_insert_iterator<Container> front_inserter (Container& x);
    
    template <class Container>
      insert_iterator<Container> inserter (Container& x, typename Container::iterator it);
    

    通过迭代器,对指向的元素调用copy assignment operator (“=”),就能触发x扩展1个新元素。上面3个迭代器都适用。

    示例1

    list<int> v1;
    // v1变成"10 20 30 40"
    auto it = back_inserter(v1);
    *it = 10;
    *it = 20;
    *it = 30;
    *it = 40;
    
    // v1变成"40 30 20 10"
    auto it = front_inserter(v1);
    *it = 10;
    *it = 20;
    *it = 30;
    *it = 40;
    
    // v1变成"10 20 30 40"
    auto it = inserter(v1, v1.begin());
    *it = 10;
    *it = 20;
    *it = 30;
    *it = 40;
    

    插入迭代器经常结合std::copy,用来将一个容器元素拷贝到另一个容器。
    示例2

    list<int> v1 = { 20, 30, 40 }, v2 = { 1, 2, 3, 4, 5, 6 };
    
    // copy调用后 v1为"20 30 40 1 2 3 4 5 6"
    copy(v2.begin(), v2.end(), back_inserter(v1));
    
    // copy调用后 v1为"6 5 4 3 2 1 20 30 40"
    copy(v2.begin(), v2.end(), front_inserter(v1));
    
    // copy调用后 v1为"1 2 3 4 5 6 20 30 40"
    copy(v2.begin(), v2.end(), inserter(v1, v1.begin()));
    
    // v2保持不变
    
    posted @ 2021-12-14 22:38  明明1109  阅读(62)  评论(0编辑  收藏  举报