使用相同的迭代器循环遍历两个 std::vector
Looping through two std::vectors using the same iterator
因此,我的一个类具有以下重载:
DVector &operator+=(DVector const &other) {
if (vector.size() >= other.vector.size()) throw up; // lol.
std::for_each(other.vector.begin(); other.vector.end(), [](DVector const &pass) {
// huh?
});
}
因此,这个想法是将两个向量的每个成员求和(嗯,每个DVector
实例都包含一个名为 vector
的std::vector<float>
成员),例如:
如果我有一个包含vector
成员的DVector
包含以下浮点数:11.0, 23.5, 12.3
,然后另一个包含14.0, 6.5, 7.7
,则两者的总和应导致第一个向量保持25.0, 25.0, 25.0
。
:有没有办法遍历两个向量并仅使用一个迭代器对它们的成员求和,假设向量的大小不是问题,还是我只是被迫使用for (auto x: vector.size())
?
干杯,朱利安。
这是一个 std::transfom 算法,它接受两个输入和一个输出迭代器。
我不知道您的特定矢量设计是如何构建的,但您应该能够根据需要修改以下内容。
std::transform(input1.begin(), input1.end(), //input1
intput2.begin(), //input2
input1.begin(), //output
[](double a, double b){
return a+b;
});
您还可以使用不同的输出迭代器operator +
也可以很好地使用。
以下是一些参考资料
http://en.cppreference.com/w/cpp/algorithm/transform
http://www.cplusplus.com/reference/algorithm/transform/
当你有不同的输出时,back_inserter是你的朋友:
http://en.cppreference.com/w/cpp/iterator/back_inserter
迭代器绑定到容器,因此不能使用单个迭代器。您必须使用一个索引或两个单独的迭代器。
如果我
正确理解您的需求:
std::transform(vec1.begin(), vec1.end(), vec2.begin(), vec1.begin(),
[](float lhs, float rhs) {
return lhs + rhs;
});
相关文章:
- 使用std::vector的OpenCL矩阵乘法
- POCO::PostgreSQL:如何将std::vector支持添加到`Binder::bind`
- std::vector的包装器,使数组的结构看起来像结构的数组
- 编译器如何区分std::vector的构造函数
- 使用 pqxx 将 std::vector 存储在 postgresql 中,并从数据库中检索它
- 在std::vector上存储带有模板的类实例
- 在main()之外初始化std::vector会导致性能下降(多线程)
- 为什么std::vector比数组慢
- std::vector::迭代器是否可以合法地作为指针
- 如何将二进制格式的 C++ 对象的 std::vector 保存到磁盘?
- 为什么std::vector和std::valarray初始化构造函数不同
- ";结果类型必须是可从输入范围的值类型""构造的;创建std::vector时
- 在没有未定义行为的情况下实现类似std::vector的容器
- 如何调整 std::vector of Eigen::MatrixXd 的大小
- 使用 std::vector::reverse_iterator 将 int 序列化为字节向量?
- 如何将AERT_Allocate与 std:vector 一起使用
- 推导 std::vector::back() 的返回类型
- 如何将原始字节附加到 std::vector?
- std::vector 没有重载函数的实例与参数列表匹配
- 如果 KEY 是 std::list 或 std::vector 而不是值,那么 std::map 的默认行为是什么?