草庐IT

C++: vector 和列表之间的混合:类似于 std::rope?

当存储一堆元素并且我不需要随机访问容器时,我使用了std::list这大部分都很好。然而,有时(尤其是当我只是将条目推回后面并且从不删除中间的某个地方时),我希望我有一些具有更好性能的结构来添加条目。std::vector不好是因为:如果它不再适合,它必须重新分配。它不适用于大量数据(因为您不能总是获得非常大的连续空闲内存块)。std::list不好是因为:它对每个push_back进行分配。这很慢并且会导致大量内存碎片。所以,介于两者之间的东西就是我想要的。基本上,我想要类似std::list>的东西或者。或者也许可以代替100,让它成为4096/sizeof(T).也许还有std:

c++ - 使用迭代器将部分文件流读入字符串

这是我到目前为止尝试过但没有成功的方法:std::stringReadPartial(std::ifstream&_file,int_size){std::istreambuf_iteratorfirst(_file);std::istreambuf_iteratorlast(_file);std::advance(last,_size);returnstd::string(first,last);}我知道如何阅读整个文件。std::stringRead(std::ifstream&_file){std::istreambuf_iteratorfirst(_file);std::ist

c++ - c++ 中 std::next_permutation() 函数的时间复杂度是多少?

我想知道next_permutation函数的时间复杂度。我也可以查看它的代码吗? 最佳答案 参见http://www.sgi.com/tech/stl/next_permutation.html:Linear.Atmost(last-first)/2swaps.要查看源代码,只需查看系统的STL头文件即可。在类Unix系统上,您可能需要查看类似/usr/include/c++/4.1.2/bits/STL_algo.h的地方。 关于c++-c++中std::next_permutati

c++ - 将 std::vector 传递给修改输入数组的函数

我正在使用第三方API(准确地说是CryptEncrypt),它将C数组作为输入输出参数。从逻辑上讲,API归结为以下功能:voidadd1(int*inout,size_tlength){for(size_ti=0;i我试图避免使用原始数组,所以我的问题是我可以使用std::vector作为上述API的输入吗?类似于以下内容:#includeintmain(){std::vectorv(10);//vectorwith10zerosadd1(&v[0],v.size());//vectorwith10ones?}我可以使用vector的“连续存储”保证向它写入数据吗?我倾向于相信这没

c++ - 改变 const std::string 引用的引用

我正在研究C++中的引用,并注意到一些我无法解释的奇怪行为。我的理解是,如果我有一个非常量变量和对同一变量的const引用,然后修改非常量变量,该引用应该反射(reflect)该修改。例子:voidfoo(){intx=5;constint&y=x;x=10;std::cout为我生成以下输出:x=10y=10但是,如果我将类型更改为std::string,const引用似乎不会反射(reflect)修改后的变量:voidfoo(){std::stringx="abc";conststd::string&y=x;x="xyz";std::cout为我生成以下内容:x=xyzy=abc这

c++ - 修复(锁定)std::vector 的大小

有没有一种方法可以固定vector的大小并仍然改变内容?我尝试制作一个constvectorconststd::vectorvec(10);但这会阻止我更改值。vec[3]=3;给出编译器错误:分配只读位置。我也尝试过对非常量vector的常量引用std::vectorvec(10);conststd::vector&vecref(vec);这给出了相同的编译器错误。我希望能够在声明时或初始化阶段后修复vector大小。我可以使用老式数组,但我希望能够使用vector算法。如果有任何不同,我正在使用g++。 最佳答案 在C++0x中

G++ 4.5 中 std::complex 的 C++11 复制赋值 - 与 'operator+' 不匹配

下面的代码无法使用-std=c++0x开关在g++4.5.0版中编译。我收到以下错误消息:error:nomatchfor'operator+'in'std::pow[with_Tp=float,_Up=int,typename__gnu_cxx::__promote_2::__type=double](((conststd::complex&)((conststd::complex*)(&x))),((constint&)((constint*)(&2))))+y'我相信这与提到的可分配要求有关here.我应该为complex定义自己的复制赋值运算符吗?如果是,怎么办?#includ

c++ - 逆序获取 `std::priority_queue`个元素?

我编写了一些K最近邻查询方法,这些方法构建了一个最接近给定查询点的点列表。为维护该邻居列表,我使用std::priority_queue使得顶部元素是距查询点最远的邻居。这样我就知道我是否应该推送当前正在检查的新元素(如果距离比当前最远的邻居更小)并且当我的优先级队列有超过K个元素时可以pop()最远的元素。到目前为止,一切都很好。但是,当我输出元素时,我想从最近到最远的顺序排列它们。目前,我只是简单地从优先级队列中弹出所有元素并将它们放在输出容器中(通过迭代器),这会产生从最远到最近排序的点序列,然后,我调用std::reverse在输出迭代器范围上。作为一个简单的例子,这是一个使用

c++ - 编译器首先返回 "synthesized method ‘operator=’ 此处需要”

我知道这可能是一个简单的问题,但过去一个半小时我一直在研究它,我真的迷路了。这里是编译错误:synthesizedmethod‘File&File::operator=(constFile&)’firstrequiredhere我有这段代码:voidFileManager::InitManager(){intnumberOfFile=Settings::GetSettings()->NumberOfFile()+1;for(unsignedinti=1;i_files如果在此header中定义:#pragmaonce//C++Header#include//CHeader//local

c++ - 无效的模板相关成员函数模板推导 - 认为我正在尝试使用 std::set

我有一个继承自基类模板的类模板。基类模板有一个数据成员和一个我想从父类(superclass)中调用的成员函数模板。我知道为了消除对成员函数模板的调用的歧义,我必须使用template关键字,我必须明确提及this在父类(superclass)中。this->base_member_obj.templatemember_function();这一切都很好,只是我使用的代码库犯了一个相当不幸的错误,即导入了整个namespacestd。,我试图调用的模板成员函数称为set.框架中的某处std::set包含在内,这导致GCC认为我正在尝试声明std::set而不是调用成员函数set.GCC