使用另一个向量中的值对一个向量进行排序
Sorting a vector using values in another vector
我有一个名为foo_vec
的std::vector
,其中包含类Foo
的对象。假设Foo
有一个成员变量int x
,我还实现了一个函数CompareInts(int a, int b)
,它返回a
和b
的最小值。然后,我可以做一个std::sort
,即根据对象的x
值的向量。
然而,如果这些x
值不是Foo
的成员变量,而是在另一个称为x_vec
的std::vector
中,该怎么办。这里,x_vec
的第一个元素对应于foo_vec
的第一个元件,依此类推。如何根据x_vec
中的对应值对foo_vec
执行std::sort
?
您可以制作索引的第三个向量,并对其进行间接排序。排序后,您可以通过已排序的索引访问原始矢量:
std::vector<Foo> foo_vec = /* ... */;
std::vector<int> x_vec = /* ... */;
std::vector<std::size_t> index_vec;
assert(foo_vec.size() == x_vec.size());
for (std::size_t i = 0; i != foo_vec.size(); ++i) { index_vec.push_back(i); }
std::sort(
index_vec.begin(), index_vec.end(),
[&](std::size_t a, std::size_t b) { return x_vec[a] < x_vec[b]; });
for (std::size_t i = 0; i != index_vec.size(); ++i)
{
std::cout << "Sorted element " << i << " is "
<< foo_vec[index_vec[i]] << "n";
}
请注意,这种操作完全是非侵入性的,因为一切都是间接发生的。
创建第三个int向量,这是原始两个向量的索引。最初用数字0填充第三个矢量。。向量的长度。然后构造比较函数,从第三个向量中获取索引,然后与持有键的第二个向量进行比较。
第一个和第二个矢量中的数据将不会被修改(这很好),第三个矢量的值将表示排序顺序。
相关文章:
- 函数向量_指针有不同的原型,我可以构建一个吗
- 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 的向量的指针
- 紧凑向量一个小的内存足迹向量