将一个向量与另一个向量排序

问题描述 投票:0回答:2

我正在尝试按另一个向量对向量进行排序。

例如:

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
c++ vector
2个回答
0
投票

您需要一个自定义比较,可以在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


0
投票

您可以使用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

© www.soinside.com 2019 - 2024. All rights reserved.