草庐IT

STL容器之queue

全部标签

c++ - STL中的Union-Find(或Disjoint Set)数据结构?

我原以为C++标准库中会包含这样一个有用的数据结构,但我似乎找不到。 最佳答案 不是,但是boost里有:http://www.boost.org/doc/libs/1_64_0/libs/disjoint_sets/disjoint_sets.html,所以如果您想要一个现成的实现,我会推荐这个。 关于c++-STL中的Union-Find(或DisjointSet)数据结构?,我们在StackOverflow上找到一个类似的问题: https://stac

使SVG容器100%宽度和D3 V4中的母容器的高度(而不是由像素)

我有一个父容器(div.barchartcontainer),其高度和宽度是根据视口计算的,例如:ex:width:calc(100VH-200px)。SVG容器附加到Div.BarchartContainer元素。我为如何使SVG元素成为其父元素的宽度和高度而苦苦挣扎,希望我能得到一些帮助。目前,我有静态像素量(当前正确渲染的位置,但反应迅速)。谢谢!varmargin={top:20,right:20,bottom:30,left:80},width=960-margin.left-margin.right,height=500-margin.top-margin.bottom;//set

c++ - 如何在 C 库的实现文件中使用 C++ STL 容器?

假设我希望在我希望C程序链接到的库的实现中使用C++STL容器...我的示例header是/*mynums.h*/#ifndefMY_NUMS#defineMY_NUMS#ifdef__cplusplusextern"C"{#endifvoidappend_num(intnum);voidprint_nums();#ifdef__cplusplus}#endif#endif我的示例实现文件是/*mynums.cpp*/#include"mynums.h"#includeusingstd::vector;vectornums;voidappend_num(intnum){nums.pus

c++ - 推导容器和 initializer_list-s 的模板函数

我想编写一个辅助函数,例如:templateautohelper(constRange1&left,constRange2&right,F&&pred){usingnamespacestd;//forcbegin/cendandADLreturnpred(cbegin(left),cend(left),cbegin(right),cend(right));}它适用于容器:std::vectorv1={1,2,3,4,5,6};std::vectorv2={5,4,3,2,1,6};std::cout但它无法推断出initializer_list-s(example):std::cout

c++ - STL bitset::count() 方法的性能如何?

我四处搜索,找不到bitset::count()的性能时间规范。有人知道它是什么(O(n)或更好)以及在哪里可以找到它吗?编辑由STL我仅指标准模板库。 最佳答案 我在我的电脑上读取了这个文件(C:\cygwin\lib\gcc\i686-pc-cygwin\3.4.4\include\c++\bitset)。看这些///Returnsthenumberofbitswhichareset.size_tcount()const{returnthis->_M_do_count();}size_t_M_do_count()const{si

C++ STL 优化警告 : problem with the code or something more sinister?

我有一个正在开发的程序,我正在从使用数组切换到使用vector,但我遇到了问题。我将其简化为:#includeclassA{public:A(void);~A(void);private:std::vector>a;};A::A(void):a(){}A::~A(void){}这从g++(标志:-O2-Wunsafe-loop-optimizations,版本4.4.3(Ubuntu4.4.3-4ubuntu5)在Ubuntu10.04x86_64上)发出以下警告:/usr/include/c++/4.4/bits/STL_construct.h:在析构函数‘A::~A()’中:/us

C++的Odyssey之旅——STL

W...Y的主页😊代码仓库分享💕 🍔前言:我们已经将基本语法了解的差不多了,现在我们就该进入C++中最重要也是最富有特点的一部分——STL。在学习C语言中我们想要使用顺序表、链表等一些数据结构进行做题时都需要进行这些结构的创建,当我们学习后STL就再也不用考虑这些问题了,下面让我们一起走入STL的世界。目录 什么是STLSTL的版本STL的六大组件STL的重要性 如何学习STLSTL的缺陷与不足  什么是STLSTL(StandardTemplateLibrary)是C++的一个重要组成部分,它提供了一组通用的模板类和函数,用于实现常见的数据结构和算法。STL的设计目标是提供一种通用、高效、可

c++ - 是否保证像 std::queue 这样的 C++ 标准库容器是可重入的?

我见过有人建议我应该将标准容器(如std::queue和std::vector)包装在互斥锁或类似的容器中(如果我想使用它们的话)。我读到需要为多个线程访问的容器的每个单独实例锁定,而不是每个类型或c++标准库的任何使用。但这假设标准容器和标准库保证是可重入的。语言中有这样的保证吗? 最佳答案 标准说:Exceptwhereexplicitlyspecifiedinthisstandard,itisimplementation-definedwhichfunctionsintheStandardC++librarymayberecu

c++ - 一些 STL 容器的 std::allocator 不匹配

使用不匹配的std::allocator特化(当然,除了它对void的特化)作为STL容器(不是所有容器)的模板参数在技术上是否有效,但下面列举的加上unordered_(multi)map/set)?以下代码编译正常。#include#include#include#include#includeintmain(){structA{booloperator>l;std::forward_list>fl;std::deque>d;std::set,std::allocator>s;std::multiset,std::allocator>ms;std::map,std::allocat

c++ - 如果类包含标准容器,我可以将类 move 操作标记为 noexcept 吗?

在具有标准容器成员的类上实现move操作的惯用方法不能是noexcept因此不能通过vector.push_back()等操作move.还是我弄错了?从中获取速度vectordata;//...data.push_back(elem);鼓励我们进行move操作noexcept--因此在vector调整大小时,库可以安全地将元素move到重新分配的存储空间。classElem{//...Elem(Elem&&)noexcept;//noexceptimportantformoveElem&operator=(Elem&&)noexcept;//noexceptimportantformo