二进制搜索std:map
binary search a std:map
使用c++,如果我在std::map
中有n
整数,是否可以有效地搜索std::map
中小于k
的最大元素?
例如,我有{1, 3, 5, 6}
,而k
是4返回的值应该是3
我知道std::map
可以在log(n)
中搜索,如果它完全匹配的话。
使用lower_bound
并将返回的迭代器递减一。
您可以使用方法lower_bound
。例如
#include <iostream>
#include <map>
int main()
{
std::map<int, int> m = { { 1, 0 }, { 3, 0 }, { 5, 0 }, { 6, 0 } };
auto it = m.lower_bound( 4 );
if ( it != m.begin() )
{
std::cout << ( --it )->first << std::endl;
}
return 0;
}
查看std::map::lower_bound()
。请注意,如果有匹配项,它将返回一个完全匹配项。std::set
也有这种情况。
相关文章:
- 存储在 std::map/std::set 中,与在存储所有数据后对向量进行排序
- 如何在<N>不发生内存泄漏的情况下同时(线程安全)填充 c++11 std::map<std::string,std::bitset*>?
- 无法在 std::map<std::string,std::shared_ptr 中设置值<class>>
- 如何在C++中迭代集合映射(std::map<std::set< char>, int >)?
- 如何初始化结构字段 std::map<std::string, std::string>称为参数
- issue with std::map std::find
- 为什么 std::map< std::map >不释放内存?
- C++ map<std::string> vs map<char *> 性能(我知道,"again?" )
- 确定运行时std::map/std::set的内存使用情况
- 映射上的模板参数无效 std::map< std::string, Stock*> &Stock
- 我的SFINAE检查std::map/std::vector有什么问题
- 使用 std::map<std::string, int> 计算表达式树
- 将数据从两种不同的数据结构插入 std::map <std::string, int> mymap 并通过套接字发送
- 类中的编译器错误,数据类型为 typedef map<std::string,std::p air<std::string,vector<int>>> MapPai
- C++ std::map<std::string, std::set<std::string>> .如何循环设置值?
- 如何填写和访问 std::map<std::p air<enum1, enum2>, funcPtr>?
- 二进制'<':找不到 map<std::string shared_ptr 的运算符<Foo>>
- 如何将 2 个字符* 数组直接映射到 std::map<std::string,std::string>
- C++ std::map<std::string, int> 获取键以特定字符串开头的值
- 从取消引用的迭代器返回 std::map<std::string, int> 时出现巨大的内存泄漏