繁体   English   中英

如何将向量插入到特定位置的另一个向量中,以便我将获得两者的大向量并且该位置将被覆盖?

[英]How to insert a vector into another vector in a specific place so that i will get a big vector of both and that place will be overwritten?

对于一个练习,我真的需要知道如何将一个向量插入另一个向量。

这是我需要的一个例子:

//let's say i have these 2 vecs: 
vec1 = { 18, 192, 34};
vec2 = { 171, 11, 50, 6};

我选择连接它们的点,假设我选择 vec 1 放置在向量 2 的位置 2,如下所示:

result_vec = { 171, vec1, 50, 6};

所以当我完成后我实际上会得到的是:

result_vec = { 171, 18, 192, 34, 50, 6};

对我来说,看两个例子会更好,一个简单的例子和另一个带有智能指针的例子,如 shared_ptr 或 unique_ptr。

谢谢!

有时浏览一些参考资料并查看容器提供的方法会有所帮助。 大多数时候,您会发现有一种方法可以开箱即用。 在这种情况下,它是std::vector::insert (重载 (4))。 要删除该位置的旧元素,您可以使用std::vector::erase

#include <iostream>
#include <vector>

int main() {
    std::vector<int> vec1{ 18, 192, 34};
    std::vector<int> vec2{ 171, 11, 50, 6};
    vec1.insert(vec1.begin()+1,vec2.begin(),vec2.end());
    vec1.erase(vec1.begin()+1);
    for (int e : vec1) std::cout << e << ' ';
}

Output:

18 11 50 6 192 34 

我反过来插入,但它应该很容易调整。 对智能指针做同样的事情也不需要使用不同的算法/方法。 如果要保留原始矢量,则只需在插入前进行复制。

PS:我首先误读了问题,错过了在您插入的地方删除元素的部分。 我的固定解决方案不是最有效的,因为插入和擦除旧元素可以在一个 go 中完成。 但是,对于不太大的向量,效率的差异可能可以忽略不计。

您似乎想用一个向量的一个元素替换另一个向量的元素。 如果是这样,那么您可以编写类似于演示程序中所示的 function。

#include <iostream>
#include <vector>
#include <iterator>

template <typename T>
std::vector<T> & replace( std::vector<T> &v1, 
                          typename std::vector<T>::size_type pos,
                          const std::vector<T> &v2 )
{
    if ( not ( pos < v1.size() ) )
    {
        v1.insert( std::end( v1 ), std::begin( v2 ), std::end( v2 ) );
    }
    else
    {
        v1.insert( v1.erase( std::next( v1.begin(), pos ) ),
                   std::begin( v2 ), std::end( v2 ) );
    }

    return v1;
}                          

int main() 
{
    std::vector<int> v1 = { 171, 11, 50, 6 };
    std::vector<int> v2 = { 18, 192, 34 };

    for ( const auto &item : replace( v1, 1, v2 ) ) std::cout << item << ' ';
    std::cout << '\n';

    return 0;
}

程序 output 是

171 18 192 34 50 6 

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM