如何在C++中得到一个元素在向量中的秩

How to get the rank of an element in vector in C++

本文关键字:一个 元素 向量 C++      更新时间:2023-10-16

我需要为C++中的容器(如vectorlist)获取元素的秩(位置索引+1)。有方便的方法吗?我本可以根据nth_element进行测试,以找到排名。或者我可以排序并进行二进制搜索来找到排名。但在最坏的情况下,所有这些似乎都不是很有效。我想得到O(lgn)的复杂性,并尽可能使用STL算法。

如果您的容器具有随机访问迭代器(例如vector)并进行了排序,则可以使用std::lower_bound()算法获得复杂度为O(logn)的元素索引。例如:

std::vector<int> v({10,20,30,30,20,10,10,20});
std::sort(v.begin(), v.end());
auto iter = std::lower_bound(v.begin(), v.end(), 20);
std::cout << "index " << int(iter - v.begin()) << std::endl;

(我使用C++11语法来保持代码简短,但您应该了解这个想法)。

请注意,您可以以排序的方式将元素插入到向量中,因此在查找索引之前不需要进行排序。

您似乎不太可能在这里找到比线性搜索更高效的东西。最糟糕的情况一定是将所有元素与搜索内容进行比较,而这正是线性搜索所能提供的。

这可能有点不整洁。

您可以使用向量中的元素在内存中是连续的这一事实。

所以你要做的是

1) 获取感兴趣元素的迭代器地址

2) 用vector.begin()相减得到总内存

3) 除以一个元素的大小

这应该给你职位(或级别)。

这是假设元素是固定大小的。