gpt4 book ai didi

c++ - 如何以最有效的方式在已排序的 C++ vector 中查找值?

转载 作者:IT老高 更新时间:2023-10-28 12:40:59 26 4
gpt4 key购买 nike

我看过 findbinary_search ,但 find 没有利用 vector 已排序这一事实,并且 binary_search 只返回真或假,而不是它找到值的位置。有什么功能可以让我两全其美?

最佳答案

您可以使用 find 在 O(N) 时间内定位任何容器中的特定元素。使用 vector ,您可以进行随机访问并利用 std 算法的 lower_bound (log2(N))、upper_bound 或 equal_range 类。 std::lower_bound会为你做的。它位于 binary_search 顶部的等效行为部分。但是,binary_search 的用处仅限于yes 和no 答案(可能在未来的C++ 版本中命名需要改进;binary_in())。

关于c++ - 如何以最有效的方式在已排序的 C++ vector 中查找值?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/18994602/

26 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com