【发布时间】:2021-01-19 07:49:12
【问题描述】:
给定下面的代码,它只是将向量的每个元素加 1:
#include <iostream>
#include <vector>
#include <algorithm>
int main()
{
// Create vector 1 - print it out
std::vector<int> v1 {1,2,3,4,5,6,7,8,9};
for (auto val : v1)
{
std::cout << val << " ";
}
std::cout << std::endl;
// Create vector 2 by a transform of vector 1 + 1
std::vector<int> v2(v1.size());
std::transform(v1.begin(), v1.end(), v2.begin(),
[](int val){ return val + 1; });
// Print out vector 2
for (auto val : v2)
{
std::cout << val << " ";
}
std::cout << std::endl;
}
我想添加前一个元素的值,而不是只为每个值加 1,以便:
v[0] = v[0] (no previous value)
v[1] = v[1] + v[0]
v[2] = v[2] + v[1]
etc...
所以我最终得到:
1 = 1
2 + 1 = 3
3 + 2 = 5
4 + 3 = 7
etc...
这是一个愚蠢的例子 - 它不是数学难题或类似的东西,我只是想弄清楚我是否可以在我的向量中使用其他值,而不是传递给 lambda 函数的值?
我在 lambda 中丢失了两位数据:
std::transform(v1.begin(), v1.end(), v2.begin(), [](int val){
// What is the index of val?
// What is the size of the vector v1?
// How would I express this:
if (INDEX_OF(val) > 0)
return val + INDEX_OF(val - 1);
else
return val;
});
我可以通过捕获传递 v1 并使用它来进行一些计算,但由于我不知道索引,所以不是我想要的。
std::transform(v1.begin(), v1.end(), v2.begin(),
[&v1](int val){ return val + v1.size() - v1[0]; });
也许转换不是这项工作的工具,我需要诉诸迭代器循环?:
std::vector<int> v2(v1.size());
auto it2 = v2.begin();
for (auto it1 = v1.begin(); it1 != v1.end(); it1++, it2++)
{
std::distance(v1.begin(), it1) == 0 ? *it2 = *it1 : *it2 = *it1 + *(it1 - 1);
}
这可行,但我的问题是要知道它是否可以使用 std::transform 或其他算法来完成?
【问题讨论】: