将std::sets合并为std::vector

Merging std::sets into std::vector

本文关键字:std vector sets 合并      更新时间:2023-10-16

考虑以下内容:

我有两个std::set,我想把它们按顺序合并到std::vector中。

哪一种方法最有效?

我做过类似的事情,但我认为一定有更好的方法。

std::set<int> S1;
std::set<int> S2;
// ....
// Initialization of sets
// ....
std::vector V;
std::set<int>::iterator iter;
for(iter = S1.begin(); iter!=S1.end(); ++iter)
{
    V.push_back(*iter);
}
for(iter = S2.begin(); iter!=S2.end(); ++iter)
{
    V.push_back(*iter);
}
std::sort(V.begin(), V.end());
这是我的代码,有没有更有效的方法?

std::merge应该可以解决这个问题,因为S1和S2是排序的:

// Initialization of sets
// ....
std::vector V;
std::merge(S1.begin(), S1.end(), S2.begin(), S2.end(), std::back_inserter(V));

//而不是V.begin()——感谢更正

我相信你可以通过使用std::copy():

来简化你的代码
std::copy(S1.begin(), S1.end(), std::back_inserter(V));
std::copy(S2.begin(), S2.end(), std::back_inserter(V));
std::sort(V.begin(), V.end());

这些集合已经排序过了,所以在最后重新排序似乎很浪费。

不如这样做(留下几个待办事项作为读者的练习!):

  std::set<int>iterator S1iter = S1.begin();
  std::set<int>iterator S1iter = S2.begin();
  while( S1iter != S1.end() && S2iter != S2.end() ) {
    if( S1iter == S1.end() ) {
       //TODO:  S1 is finished, so push back range S2iter->S2.end()
       //       onto the vector
       break;
    }
    else if( S2iter == S2.end() ) {
       //TODO:  S2 is finished, so push back range S1iter->S1.end()
       //       onto the vector
       break;
    }
    else if( *S1iter < *S2iter ) {
      V.push_back( *S1iter );
      ++S1iter;
    }
    else {
      V.push_back( *S2iter );
      ++S2iter;
    }
  }

您可以使用std::merge(): http://en.cppreference.com/w/cpp/algorithm/merge

它的实现与您的类似。