具有固定增长的 STL 容器
STL containers with fixed growth
我有一个容器用例,它提供固定的增长模式而不是指数增长模式。在此用例中,节省内存比运行时更重要。
有没有办法使std::vector
或std::list
自动增长 N 个元素,而不是在容器空间不足时呈指数增长?
我知道我可以编写一个适配器来做到这一点,但我首先想知道它是否可以通过标准化方法实现。
如果不可能,是否有我可以使用的提升容器?
std::list
不会呈指数级增长,它是一个双重链表。
std::vector
不能按恒定数量的元素增长,因为标准要求的操作很复杂。例如,push_back
的复杂性应具有O(1)
摊销时间复杂度。随着尺寸的恒定增长,复杂性将O(n)
。
如果您需要一个与std::vector
非常相似且没有指数增长因子的容器,请查看std::deque
.
相关文章:
- 在STL容器中使用模板类
- 检查函数返回类型是否与STL容器类型值相同
- 为什么 STL 容器适配器堆栈中的 top 返回常量引用?
- 如果我真的真的想从 STL 容器继承,并且我继承构造函数并删除新运算符,会发生什么?
- 对象 C++ 向量的 STL 容器
- 如何在不破坏现有应用程序的情况下更改 API 中 stl 容器的数据类型?
- 在 STL 容器的 STL 容器上调用 clear
- "迭代器"和"const_iterator"不是 STL 容器的必需成员?
- 删除包含包含动态对象的 STL 容器的智能指针
- C++:在子类中扩展静态 STL 容器/映射成员?
- ostream 运算符<< 为获取 STL 容器而过载,传递 std::string 会破坏它?
- 没有 STL 容器的迭代器
- 为什么某些 STL 容器(堆栈、队列、优先级队列)不支持迭代器?
- 接受任何 STL 容器的函数
- C++ STL 容器中优先级搜索的优雅方法
- 我们如何打印出C++ STL 容器的value_type?
- 获取嵌套 stl 容器的大小(以字节为单位)
- 如何在C++中重新实现包含指针的 STL 容器的类的迭代器
- 迭代器和 STL 容器的关系
- 如何用索引增量generate_n填充STL容器