首页 >后端开发 >C++ >如何在保留原始索引的同时对 C 中的向量进行排序?

如何在保留原始索引的同时对 C 中的向量进行排序?

DDD
DDD原创
2024-12-25 02:50:13290浏览

How Can I Sort a Vector in C   While Preserving Original Indices?

C 中的索引保留排序

在数据操作领域,排序是将元素排列成所需顺序的基本操作。虽然排序算法本质上保留相等元素的顺序,但可能需要跟踪已排序元素的原始索引以维护其原始上下文。

解决此问题的一种方法是使用 C 11 中的 lambda 函数。 lambda 是一个匿名函数,可以从其周围范围捕获变量。这允许简洁灵活的排序操作,可以访问外部数据。

这是一个自定义的 sort_indexes 函数,它将 lambda 与标准库的 stable_sort 算法相结合:

#include <vector>
#include <algorithm>

using namespace std;

template <typename T>
vector<size_t> sort_indexes(const vector<T> &v) {

  // Initialize original indexes
  vector<size_t> idx(v.size());
  iota(idx.begin(), idx.end(), 0);

  // Sort indexes based on values in v
  stable_sort(idx.begin(), idx.end(),
               [&](size_t i1, size_t i2) { return v[i1] < v[i2]; });

  return idx;
}

在这个函数中,我们首先使用输入向量 v 的原始索引初始化向量 idx。然后,我们使用 stable_sort 基于 lambda 比较器对索引进行排序,该比较器比较使用 stable_sort 可确保具有相等值的元素在排序结果中保持其原始顺序。

要使用此函数,只需将元素向量作为参数传递,它将返回一个向量排序索引。例如,给定一个向量 [5, 2, 1, 4, 3],返回的向量 idx 将是 [1, 2, 4, 3, 0]。

此技术使您能够对元素进行排序保留其原始索引,为后续数据处理任务提供灵活性。

以上是如何在保留原始索引的同时对 C 中的向量进行排序?的详细内容。更多信息请关注PHP中文网其他相关文章!

声明:
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn