草庐IT

Circle-Map

全部标签

c++ - 是否有平面未排序的 map /集合实现?

有boost.containerflat_map和其他,还有LokiAssocVector和许多其他类似的保持元素排序的东西。是否有一个现代的(c++11支持移动等)实现未排序的vector作为映射/集合?我们的想法是将它用于非常小的映射/集合(少于20个元素)和简单的键(哈希并不总是有意义) 最佳答案 是这样的吗?templateclassStorage=std::vector>structflat_map{structkv{Keyk;Valuev;templatekv(K&&kin,V&&vin):k(std::forward(

c++ - 使用 std::tm 作为 std::map 中的键

我想使用std::tm()作为std::map容器的键。但是当我尝试编译它时,出现了很多(10)个错误。例如:1.errorC2784:'boolstd::operator&,const_Elem*)':couldnotdeducetemplateargumentfor'conststd::basic_string&'from'consttm'c:\programfiles(x86)\microsoftvisualstudio10.0\vc\include\xfunctional1252.errorC2784:'boolstd::operator&)':couldnotdeducete

c++ map/set 迭代器不可取消引用

我想向您请教,因为我是初学者,在互联网上找不到合适的答案。我收到此错误:调试断言失败-映射/设置迭代器不可取消引用在看起来像这样的行:pointA=active->pointNext(timeNext);使用pointNext()函数,我看到一切正常,并且关注active,我有:active=setS.data.end();更多信息:active是multiset::const_iteratorsetS有:setS.Q、setS.W、setS.T和setS.data,其中setS.data在方括号内有0。当我在.cpp文件中有多重迭代器声明时,在调试期间我无法进入以查看事件内部的内容,

c++ - std::map 的时间复杂度是多少

std::map的时间复杂度是多少?在最坏的情况下它会退化吗?还是由执行决定,我们不知道? 最佳答案 查找与log(N)成正比。在典型情况下(作为红黑树实现)比较次数最多可达两倍Log2N。插入通常也与Log2N成正比——但是当您插入一些已经有序的项目时有一个特殊规定1。在这种情况下,您可以为将要进行插入的位置指定一个“提示”。当该提示正确时,每次插入都是(分摊)O(1)而不是O(LogN),因此按排序顺序插入一系列项目是线性的而不是Nlog(N)。您指定的提示是指向要插入的项目之后位置的迭代器。例如,如果您在一个文件中有一些按排序

c++ - 在 map 中就地构建不可 move 的对象

我正在尝试在包含原子的映射中构造一个对象,因此它既不能复制也不能moveAFAICT。我的C++读物reference是mapemplace应该能够做到这一点。但是由于删除或不存在的构造函数,以下代码无法编译。使用make_pair没有帮助。#include#includeclassZ{std::atomici;};std::unordered_mapmap;voidtest(void){map.emplace(0,Z());//errormap[0]=Z();//error}这可能吗,如果不可能,为什么不呢?编辑:Linux上的编译器是gcc4.8.1 最

c++ - 何时为键值数据选择 std::vector 而不是 std::map?

考虑到在主内存中搜索时缓存和数据局部性的积极影响,我倾向于使用std::vector与std::pair-喜欢键值项并对两者执行线性搜索,如果我知道键值项的总量永远不会“太大”而不会严重影响性能。最近我遇到了很多情况,我事先知道我将有大量键值项,因此选择了std::map从头开始。我想知道在上述情况下,您是如何决定使用合适的容器的。你会吗总是使用std::vector(或类似)?总是使用std::map(或类似)?对项目计数范围内的哪一个比另一个更可取有直觉吗?完全不同的东西?谢谢! 最佳答案 我很少将std::vector与线性搜

红黑树,以及其在C++的set、map等数据结构中应用

红黑树介绍:红黑树(Red-BlackTree)是一种自平衡的二叉搜索树,它在插入和删除操作后通过一系列的旋转和着色操作来维持平衡。红黑树的命名来自于节点上的额外颜色属性,每个节点要么是红色,要么是黑色。红黑树的特性:1.每个节点要么是红色,要么是黑色。2.树的根节点是黑色的。3.所有叶子节点(NIL节点,空节点)都是黑色的。4.如果一个节点是红色的,则其子节点必须是黑色的。5.从根节点到叶子节点的每条路径上,黑色节点的数量相同。这些特性保证了红黑树的关键性质:任意节点到其子孙节点的最长简单路径不超过其他路径的两倍,从而确保了红黑树的平衡性。在C++的标准库中,`std::set`和`std:

c++ - If-else-if 与 map

假设我有这样一个if/else-if链:if(x.GetId()==1){}elseif(x.GetId()==2){}//...50moreelseifstatements我想知道的是,如果我保留一张map,它在性能方面会不会更好?(假设键是整数) 最佳答案 map(通常)是使用红黑树实现的,它提供O(logN)查找,因为树始终保持平衡。您的if语句线性列表将是O(N)最坏的情况。所以,是的,map的查找速度会快得多。许多人建议使用switch语句,这对您来说可能不会更快,具体取决于您的实际if语句。编译器有时可以通过使用O(1)

c++ - std::map 中的元素是否保证有序?

这只是实现的副作用(红黑树)还是顺序由c++标准保证? 最佳答案 有序迭代不是实现细节;它由C++标准保证。它是所有关联容器的基本属性(C++03§23.1.2/9):Thefundamentalpropertyofiteratorsofassociativecontainersisthattheyiteratethroughthecontainersinthenon-descendingorderofkeyswherenon-descendingisdefinedbythecomparisonthatwasusedtoconstr

c++ - 使用 QString 作为 std::unordered_map 中的键

我正在尝试使用QString作为std::unordered_map中的键,但是我得到了错误:errorC2280:'std::hash::hash(conststd::hash&)':attemptingtoreferenceadeletedfunction我无法切换到QHash,因为映射的值类型是不可复制的。有什么方法可以使它起作用吗? 最佳答案 将hash实现放在header中,并确保在使用map的所有地方都包含该header。转发到qHash的简单实现应该就足够了:#include#include#includenamesp