按另一个向量对一个向量进行排序
Sort an Vector by another Vector
我正在尝试按另一个向量对一个向量进行排序。
例如:
vct1.push_back("need");
vct1.push_back("to");
vct1.push_back("sort");
vct1.push_back("this");
然后我们 habe 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
所以现在我想按 vct2 对我的 vct1 进行排序 结果应该是这样的:
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
.
您可以使用<algorithm>
中的iter_swap
。这样,您可以简单地使用两个循环来执行
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 );
}
}
}
有关iter_swap
的更多信息,请参阅此处
相关文章:
- 函数向量_指针有不同的原型,我可以构建一个吗
- C++从另一个类访问公共静态向量的正确方法是什么
- 为什么我不能将一个对象push_back到属于另一个类的对象向量中?
- 给定一个向量,如何找到该向量的所有子集和的原始索引
- 获取向量C++中第一个值和最后一个值的和
- 从多个源构造一个对象,包括一个对象向量
- 为什么一个向量上的多线程操作很慢
- 基于范围的 for 循环:迭代使用一个元素扩展的向量
- C++ - 如何在结构向量中找到结构体一个成员的最大值?
- 如何在 C++11 中查找和更新向量中的一个嵌套结构
- Lower_bound不适用于具有 3 个元素的向量的最后一个元素
- 将一个向量插入另一个向量的某个位置
- std::find,返回所有找到的值的替代方法,而不仅仅是存在重复的向量的第一个值
- 将指向给定子类的指针从一个向量复制到另一个向量
- 如何创建一个类,以便向量工作 std::vector<MyClass<int>> v{ 1,2,3 };
- C++ STD 函数运算符:有没有一种方法可以通过函数将一个向量映射到另一个向量上?
- 将向量之间的数字放在另一个向量之间<vector>>如果两个数字的差值为 1
- 如何在不复制的情况下将一个向量移动到另一个向量中
- 创建一个函数的 Python 绑定,返回指向带有 boost 的向量的指针
- 紧凑向量一个小的内存足迹向量