草庐IT

c++ - vector 的 vector 到一维数组

我想知道是否有一种巧妙的方法可以将vector中的信息呈现为一维数组。例子:让我们创建一个包含5x3int元素的vector的vectorvector>iVector;ivector.resize(5);for(i=0;i但现在我想将此结构转换为一维数组:int*myArray=newint[5*3];所以我可以按如下方式访问我想要的每个元素:for(i=0;i我知道我可以将vector一个元素一个元素地复制到数组中,但我想知道是否有一种方法可以直接处理vector到数组的转换。我也知道vector可以作为iVector[i][j]处理,但不幸的是它需要是一个数组,因为它将被发送到GP

C++ 并行 std::vector 排序与昂贵的复制

假设我有一个vectorintVec和一个vector>matrix.我想排序intVec并对matrix的第一个维度重新排序相应地在C++中。我意识到这个问题之前已经被问过好几次了,但是这个案例有一个转折。vector复制起来很昂贵,所以例如复制intVec和matrix到vector>,对其进行排序并将它们复制回去比平时效率更低。如果没有滚动我自己的自定义排序算法,我该如何排序intVec并对matrix的第一个维度重新排序在不复制matrix的任何元素的情况下同步并调用vector的拷贝构造函数? 最佳答案 Avectoris

c++ - 为 std::map 中的 std::array 分配多个值

当使用std::array时,我可以一次赋值:std::arraya2={1,2,3};但是当上面的数组组合成一个映射时,我不知道最好的方法:usingnamespacestd;map>myMap;//I'mdoingitlikebelownow...arraytempArray={1,2,3};//canIsavethislinesomehow?myMap[myString]=tempArray;如果这实际上是正确的方法,请告诉我。谢谢! 最佳答案 虽然使用另一个答案中所示的insert效率更高,但您也可以使用myMap["foo

c++ - 如何使类在 vector 内可排序?

我有一个类说classstuff{intid;intammount;intquality;/*...*/};我有一个vectoritems.我想让我的收藏按stuff::id排序并可通过staff::id搜索.我可以通过find_if来完成,并使用一些基于STLlambda的特殊排序函数进行排序。但是我想在vector中默认拥有这一切。我听说有一些方法可以创建散列函数,但我四处搜索都找不到它...那么如何使用默认vector函数使类在vector内部可排序/可搜索? 最佳答案 为了排序,实现一个operator比较两个结构:bool

C++11 std::generate 和 std::uniform_real_distribution 调用两次给出了奇怪的结果

在不同的容器上从STL调用std::generate算法两次产生相同的结果。假设我想用-1之间的随机数填充两个float组。和1.:std::arrayx;std::arrayy;std::random_devicerd;std::mt19937_64gen(rd());std::uniform_real_distributiondis(-1.f,1.f);autorand=std::bind(dis,gen);std::generate(x.begin(),x.end(),rand);std::generate(y.begin(),y.end(),rand);您可以在这里进行测试:h

c++ - 如何编辑和重新构建 GCC libstdc++ C++ 标准库源代码?

我正在进行一些研究,并且想编辑libstdc++库中的一些源代码以进行实验。具体而言,我对试验并行排序算法很感兴趣。有什么地方可以找到文档来轻松编辑和构建源代码吗?我曾尝试构建各种版本的libstdc++库,但均未成功。似乎大多数新版本都需要构建整个gcc包,这是一个漫长得多的过程,尤其是当我要在libstdc++中编辑和试验一些文件时。我也找不到包含并行排序算法的源文件。我似乎只能找到定义函数的头文件,而不是源代码本身。非常感谢任何建议或文档链接。 最佳答案 是的,您必须构建整个GCC,但是一旦完成,您只需要重建libstdc++

c++ - 所有权应该在 STL 容器调用其值的析构函数之前还是之后结束?

在下面的代码中,一个X在全局容器中注册,成为它的共享所有者。X的析构函数测试它不再是此类所有权的一部分,我希望这是被销毁的有效先决条件。#include#includestructX{~X();};std::vector>global_x_reg;X::~X(){for(autoiter=global_x_reg.begin(),end=global_x_reg.end();iter!=end;++iter)if(iter->get()==this)throw"Oops.Xgetsdestroyedwhileitisstillowned!";}intmain(intargc,char*

c++ - std::vector of function pointers:不同的模板参数

为什么下面会编译std::vectorfunc_ptrs;但这不是std::vectorfunc_ptrs?在第二种情况下,我收到了那些丑陋的STL错误消息之一,所以我不打算将所有内容都放在这里,但在消息的末尾我得到了这个/usr/include/c++/4.8/bits/stl_construct.h:102:30:error:ISOC++forbidsincrementingapointeroftype‘int(*)(double)’[-fpermissive]for(;__first!=__last;++__first)这似乎暗示C++将类型int(double)转换为int(*

c++ - 将 unique_ptr 从一个集合移动到另一个集合

我似乎无法弄清楚并尝试了以下建议:Move`unique_ptr`sbetweensetshowtomoveanstd::unique_ptrfromoneSTLcontainertoanother?我有两个包含唯一指针的集合:std::set>s1,s2;指针当然是唯一的,但some_type的值可能是也可能不是,所以在将s2连接到s1之后,s1的大小可能与|s1+s2|相同或一样大。看来我应该能够做到这一点:move(s2.begin(),s2.end(),inserter(s1,s1.end()));但这在clang++3.8/g++5.4中失败了。这里缺少什么?

c++ - 为什么 reverse_iterator 有一个默认的构造函数?

我刚刚学习STL,reverse_iterator让我感到困惑。它有一个默认构造函数,但我不知道如何使用它。我试过:reverse_iteratorr{};r--;然后程序崩溃了。我认为这种用法没有意义,而且很容易导致崩溃,那么为什么允许使用默认构造函数呢? 最佳答案 std::reverse_iterator是bidirectionaliterators,它们有一个明确的要求,即它们是可默认构造的。至于whybidirectionaliteratorsaredefault-constructible,这主要是因为几乎可以肯定它们实