草庐IT

unordered-set

全部标签

c++ - 确定字符是否属于一组已知字符的最快方法 C++

给定任何字符,确定该字符是否属于已知字符集(而非容器类型)的最快方法是什么。换句话说,什么是实现条件的最快优雅的方式:charc='a';if(c==ch1||c==ch2||c==ch3...)//做点什么...是否有一个STL容器(我想它可能是unordered_set?),我可以将字符作为键传递给它,如果键存在它会返回true吗?任何具有O(1)查找时间的东西都适合我。 最佳答案 我走得更远,写了两个版本,一个基于查找数组,另一个基于使用底层哈希的集合。classCharLookup{public:CharLookup(con

C++ 是否在恒定时间内执行 std::set、std::map 等的 begin/end/rbegin/rend?

对于std::set和std::map等以对数时间查找的数据类型,实现是否需要维护开始和结束迭代器?访问begin和end是否意味着查找可能以对数时间发生?我一直假设开始和结束总是在常数时间内发生,但是我在Josuttis中找不到任何对此的证实。既然我正在做一些我需要对性能有所了解的事情,我想确保涵盖我的基础。谢谢 最佳答案 它们发生在常数时间内。我正在查看ISO/IEC14882:2003标准的第466页:表65-容器要求a.开始();(恒定的复杂性)a.end();(恒定的复杂性)表66-可逆容器要求a.rbegin();(恒定

C++ std::set::erase 与 std::remove_if

此代码有VisualStudioerrorC3892。如果我将std::set更改为std::vector-它有效。std::seta;a.erase(std::remove_if(a.begin(),a.end(),[](intitem){returnitem==10;}),a.end());怎么了?为什么我不能将std::remove_if与std::set一起使用? 最佳答案 您不能使用std::remove_if()具有const的序列部分。std::set的序列元素由Tconst组成对象。事实上,我们昨天在标准C++委员会

c++ - std:sort 与插入 std::set

我正在从cin读取一些线段。每条线段由起点和终点表示。2D。X和Y。输入未排序。它是随机排列的。(更新:但我需要它们先按X再按Y排序)我可以读取所有段,将它们存储在一个vector中,然后调用std::sort。另一方面,我可以创建一个空的std::set并在每个段到达时插入它。该集合将自动维护排序顺序。这两种方法哪种更有效?更新:输入的总大小(段数)是预先知道的。 最佳答案 您应该测量这两种方法的性能以确保确定,但可以安全地假设std::vector上的std::sort是way比插入std::set更快,因为局部效应和隐藏在树插

c++ - C++ 中的 "set"是什么?它们什么时候有用?

我很难概念化C++集,实际上是一般集。它们是什么?它们有什么用? 最佳答案 如果您在一般情况下理解集合有困难,请不要难过。大部分数学学位都花在了与集合论的相处上:http://en.wikipedia.org/wiki/Set_theory将集合视为唯一的、无序的对象的集合。在很多方面它看起来像一个列表:{1,2,3,4}但顺序并不重要:{4,3,2,1}={1,2,3,4}并忽略重复:{1,1,2,3,4}={1,2,3,4}C++集是此数学对象的实现,具有内部排序的奇怪功能。但这只是实现的细节,与理解数据结构无关。排序只是为了速

c++ - LLDB:如何检查 unordered_map

大多数其他STL容器打印良好,但unordered_map是一个烂摊子。我使用operator用于打印,但这与打印无关,这是关于当我崩溃并且我想从LLDB提示符打印出我的哈希值时。我不能调用类似callcout的东西因为那行不通。除了例如,没有其他解决方案吗?链接本身使用cout的模板函数?那行得通吗?(我正在尝试,但它不起作用,因为我必须提前知道模板参数类型是什么,以便为它们生成和链接代码) 最佳答案 您应该能够检查unordered_map对象本身,而无需对其调用方法。例如,以这个简单的程序为例:#include#include

c++ - 使用 Swig 将 std::set 转换为 ruby

我正在使用Swig在ruby​​中使用C++,目前我已经完成了文件david.h的简单示例#includeclassDavid{public:David(intx){this->x=x;}voidannounce(){printf("David%d\n",x);}intx;};还有一个像这样的swig文件%module"david"%{#include%}classDavid{public:David(intx);voidannounce();intx;};我的extconf.rb看起来像这样require'mkmf'system('swig-c++-rubylibdavid.i')o

c++ - std::unordered_map vector 下标超出范围

我正在使用std::unordered_map保存一些值,并且在添加新值时出现“vector下标超出范围”。我正在使用VisualStudio2012,错误跟踪是:std::vector>>>,std::_Wrap_alloc>>>>>>::operator[](unsignedint_Pos)Line1140C++std::_Hash,std::equal_to>,std::allocator>,0>>::_Vec_lo(unsignedint_Bucket)Line907C++std::_Hash,std::equal_to>,std::allocator>,0>>::_End(u

C++ 如何将数组作为键插入到 unordered_map 中?

您好,我曾经有一个unordered_set来保存我的16int数组,现在我需要再存储一个int作为它的桶。我想知道我是否可以将数组插入到我的unordered_set中,或者我可以使用我以前使用的相同模板吗?#include#includenamespacestd{templatestructhash>{typedefarrayargument_type;typedefsize_tresult_type;result_typeoperator()(constargument_type&a)const{hashhasher;result_typeh=0;for(result_typei

c++ - 关于 std::unordered_multimap 中键唯一性的保证

我想知道std::unordered_multimap中关键对象的唯一性在处理迭代时。我将尝试解释这一点:我需要将一些数据与map中的键类型相关联,这些数据不应在Hash中考虑。或KeyEqual元素,但我需要它来避免与其存储单独的map(出于优化目的)。所以与我的想法相关的代码如下:structKey{void*data;mutableboolattribute;Key(void*data):data(data),attribute(false){}booloperator==(constKey&other)const{returndata==other.data;}};struct