如果元素的数量已经知道,检查数组或向量中的所有元素是否相等更好?
Is it better to check if all elements are equal in an array or a vector if the number of elements is already known?
如果您已经知道要进行比较的元素数量(在我的例子中为 5),那么使用std::array
还是std::vector
更好?
for(int i=1; i<a.size(); i++)
if(a[0] != a[i]){
std::cout << "One or more elements are not equal" << std::endl;
break;
}
}
和
for(int i=1; i<myvector.size(); i++)
if(myvector[0] != myvector[i]){
std::cout << "One or more elements are not equal" << std::endl;
break;
}
}
唯一的区别是一个使用std::array
,另一个使用std::vector
,但是鉴于您知道元素的具体数量,在这种情况下是否有理由使用一个而不是另一个?
如果您在编译时知道大小,请使用std::array
.它有两个优点:
- 没有动态分配(因此,也没有访问内部数组的指针取消引用)。
size()
的值在编译时是已知的,使编译器更容易优化。例如,一个只有 5 次迭代的短循环可能会被展开,从而消除条件分支。
顺便说一句,您的编辑使两个检查相似,使您的问题更加集中,这很好,但惯用C++建议最少使用显式循环。因此,std::adjacent_find
更好,可以在两个容器上使用。
既然 eran 列出了std::array
的优点,我将列出std::vector
的优点。
- 移动速度更快。
std::vector
的移动构造函数/赋值运算符只不过是几个指针的副本(O(1) 操作)。移动std::array
需要移动每个单独的元素(O(n) 操作)。 - 它不太可能导致堆栈溢出。无论
std::vector
有多少元素,它只会在堆栈上保持很小的占用空间。std::array
的元素是对象本身的一部分,因此如果它在堆栈上,那么它的所有元素都在堆栈上。如果你只有 5 个元素,这可能不是问题,就像你说的那样。 - 它提供了对何时构造和销毁对象的更多控制。
std::array
必须在初始化时创建其所有实例。当您的类型没有默认构造函数时,这可能特别不方便,因为您需要单独键入所有初始化。使用std::vector
,您可以循环或闲暇时进行构造。
相关文章:
- 向量元素的引用地址与它所指向的向量元素的地址不同.为什么
- C++:如何循环通过向量中的整数元素
- 如何在C++向量中奇数元素前面加上值-1,我在使用insert函数时遇到了问题
- 不允许在向量中添加更多元素
- 基于范围的 for 循环:迭代使用一个元素扩展的向量
- 使用并行参数向量调用元素向量的成员函数
- C++ 查找字符串中存在的元素向量
- 包含 std::threads 的元素向量
- 避免从单一元素向量转换为基元类型
- 对自定义元素向量进行排序时出现意外(至少对我来说)行为
- 如何为对元素(向量和int)配对创建unique_ptr也是unique_ptr
- 元素向量乘法 C++(代码不起作用)
- 时间和空间复杂性在二叉树的每个级别创建元素向量(NON-BST)
- 遍历结构元素向量
- 犰狳C++中的元素向量或矩阵乘法
- 为什么'std::vector<int> b{2};'创建 1 元素向量,而不是 2 元素向量?
- 可移动元素向量的大小调整是否有效?
- 唯一元素向量的c++模板函数
- 获取索引和元素-向量问题
- 定义一个生成元素向量的函数时,正确的方法是什么?