迭代已知维度矩阵的最快方法

dar*_*een 3 c c++

我想知道在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)

lac*_*ker 6

为什么要烦扰三个嵌套的for循环?你可以做到

for (i=0; i<XMAX*YMAX*ZMAX; ++i)
{
    sum += *(arr_ptr+i);
}
Run Code Online (Sandbox Code Playgroud)