我想知道在c/c ++中迭代矩阵的最快方法是什么.
到目前为止,我提出的最佳方法是将矩阵映射到单个维度.
然后使用指针算法,任何其他可能更快的方法?
维度在运行时是已知的但不是编译时间,矩阵是完全填充的.
#include <iostream>
#include <time.h>
#define XMAX 500
#define YMAX 400
#define ZMAX 300
int main()
{
srand(0);
register double sum = 0;
register int i;
register int j;
register int k;
double *arr_ptr;
arr_ptr = new double[XMAX*YMAX*ZMAX];
for (i=0; i<XMAX*YMAX*ZMAX; ++i)
{
*(arr_ptr+i) = rand()/double(RAND_MAX);
}
clock_t start, finish;
start = clock();
for (i=0; i<XMAX; ++i)
{
for (j=0; j<YMAX; ++j)
{
for (k=0; k<ZMAX; ++k)
{
sum += *(arr_ptr+i*YMAX*ZMAX+j*ZMAX+k);
}
}
}
finish = clock();
std::cout << "sum: " << sum << "\telapsed: " << finish - start << std::endl;
std::cin.get();
delete[] arr_ptr;
}
Run Code Online (Sandbox Code Playgroud)
为什么要烦扰三个嵌套的for循环?你可以做到
for (i=0; i<XMAX*YMAX*ZMAX; ++i)
{
sum += *(arr_ptr+i);
}
Run Code Online (Sandbox Code Playgroud)