累加器在 c++ 提升库中有什么用
What is the use of accumulator in c++ boost library?
我刚刚阅读了 c++ 中的 boost 库指南。而且我不明白累加器的部分。
在指南中,它说每个累加器都可以拥有自己的功能,例如tag::min或tag::mean。如果您拥有这些功能,则可以使用 min 函数(宏)。
那么为什么我不能在 STL 中使用 vector 并使用像 min_element(v.begin(), v.end()) 这样的算法呢?使用蓄能器有什么优势?
指南也写了这些话"累加器复杂性 O(1)提取器复杂性 O(1)"。那是什么意思?它与时间复杂度有关吗?这是蓄能器的优势吗?
如果使用向量,则必须存储每个值。这需要内存,但对于累加器用于的任务,实际上不需要存储这些值 — 对于某些计算,您只需在给定新值时更新少量状态。
您可以编写一个节省空间的算法来执行计算,而无需所有存储,或者您可以使用为您完成这项工作的累加器。
此外,累加器库提供了标准库没有的一些统计工具。
而且,是的,O(1) 意味着"恒定的时间复杂度",这告诉我们这种方法的另一个重要好处——它的性能不会随着数字数量的增加而变差。
这里有一个更深入的解释。
相关文章:
- 为不同配置设置MSVC_RUNTIME_LIBRARY的正确方法是什么
- 警告处理为错误这里有什么问题
- 什么时候调用组成单元对象的析构函数
- #定义c-预处理器常量..我做错了什么
- 努力将整数转换为链表。不知道我在这里做错了什么
- C++我的数学有什么问题,为什么我的代码不能正确循环
- 什么时候在C++中返回常量引用是个好主意
- 当在同一名称空间中有两个具有相同签名的函数时,会发生什么
- C++避免重复声明的语法是什么
- c++库的公共头文件中应该包含什么
- 问题:什么是QAbstractItemView::NoEditTriggers的反面
- 有什么方法可以遍历结构吗
- 当类在C++中定义时,有什么方法可以"register"类吗?
- ifstream什么都没读
- 在C++中,将大的无符号浮点数四舍五入为整数的最佳方法是什么
- 实现无开销push_back的最佳方法是什么
- C++从另一个类访问公共静态向量的正确方法是什么
- "throw expression code" 1e7 >返回 d 是什么?投掷标准::overflow_error( "too big" ) : d;意味 着?
- 我应该使用什么来代替void作为变体中的替代类型之一
- 有没有什么方法可以使用一个函数中定义的常量变量,也可以由c++中同一程序中的其他函数使用