C++矢量迭代
C++ Vector iteration
我有一个向量int p=[n1,n2,n3]。生成另一个与P大小相同的向量的最有效方法是什么,称之为v1=[m1,m2,m3]。步骤:
- 矢量<int>P[N],N,包含n0,n1,n2
- 对于n中的每个n_i,生成大小为n0的正态随机变量的向量,然后是n1,n2
- 独立地取每个新矢量的和,sum(n0(,sum
- 创建向量v1[m1,m2,m3]。对于"i"中的每个i;v1";包含上一步骤中的随机数之和
const int N = 10;
vector<int> p;
vector <double> b;
for ( int i =0; i<N ; i++)
{
Poiss = U.RandomPoisson(Lambda); // generate N Poissonian Random variables
Normal = U.RandomNormal(4000,7000); // generate N Normal Random variable
p.push_back(Poiss);
b.push_back(Normal);
}
// iterate over P and use each element of p call it p[i] as the size of a new random vector with size p[i] call it vec[p[i]]. Take the sum of vec[p[i]] and add to a new vector call it V. The Final size of V is the same as P
for ( auto &i : p )
{
do some stuff...
}
您可能需要这样的东西:
vector<vector<int>> vec;
vector<int> v;
v.reserve(p.size());
for (auto &&i : p) {
vector<int> temp(i);
for (auto &&j : temp)
j = U.RandomNormal(4000, 7000);
v.push_back(accumulate(temp.begin(), temp.end(), 0));
vec.push_back(move(temp));
}
代替
for (auto &&j : temp)
j = U.RandomNormal(4000, 7000);
您可以直接使用:
std::generate(temp.begin(), temp.end(), [&U] () { return U.RandomNormal(4000, 7000); });
如果不需要vec
,即只需要v
内的值,则执行以下操作:
vector<int> v;
v.reserve(p.size());
for (auto &&i : p) {
int sum = 0;
for (int j = 0; j < i; ++j)
sum += U.RandomNormal(4000, 7000);
v.push_back(sum);
}
相关文章:
- 使用std::multimap迭代器创建std::list
- 来自 std::list 的迭代器 .end() 按预期返回"0xcdcdcdcdcdcdcdcd"但 .begin()
- C++中带有List类的迭代器Segfault
- 迭代时从向量和内存中删除对象
- 如何在c++迭代器类型中包装std::chrono
- 带过滤器的现代迭代c++集合
- 在c++中检查长方体是否尽可能快地重叠(无迭代)
- C++矢量迭代
- 集合上的输出迭代器:assign和increment迭代器
- Boost Spirit,获取迭代器内部语义动作
- 擦除while循环中迭代的元素
- 实现一个在集合上迭代的模板函数
- 对于set上的循环-获取next元素迭代器
- 在向量内的向量上迭代
- 为什么output_editor Concept不需要output_e迭代器标记
- TSP递归解的迭代形式
- c++17文件系统::recursive_directory迭代器()在mac上没有给出这样的目录,但在windows上
- 使用迭代器时如何访问对象在向量中的位置?
- std::vector::迭代器是否可以合法地作为指针
- 跟随整数索引列表的自定义类迭代器