我正在尝试按另一个向量对向量进行排序。
例如:
vct1.push_back("need");
vct1.push_back("to");
vct1.push_back("sort");
vct1.push_back("this");
然后我们是vct2,其中包含:
vct2.push_back("to");
vct2.push_back("need");
vct2.push_back("this");
vct2.push_back("sort");
vct2.push_back("other"); //can be ignored
vct2.push_back("string"); //can be ignored
所以现在我想按vct1对我的vct2进行排序结果应该是这样的:
vct2->results
_____________
need
to
sort
this
other
string
您需要一个自定义比较,可以在vec1
中找到位置。
auto find = [&vec1](auto & str){ return std::find(vec1.begin(), vec1.end(), str); };
std::stable_sort(vec2.begin(), vec2.end(), [find](auto & lhs, auto & rhs) { return find(lhs) < find(rhs); };
此操作将按最初出现的顺序对不在vec1
中的内容进行排序。如果您不在乎它们的显示顺序,则可以使用std::sort
。
您可以使用iter_swap
中的<algorithm>
。这样,您可以简单地使用两个循环来执行
for ( int i = 0; i < vect1.size(); ++i )
{
for ( int j = 0; j < vect2.size(); ++j )
{
if ( vect2.at( j ) == vect1.at( i ) )
{
iter_swap( vect2.begin() + j, vect2.begin() + i );
}
}
}
有关this的更多信息,请参见iter_swap