gpt4 book ai didi

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

转载 作者:太空狗 更新时间:2023-10-29 23:31:25 24 4
gpt4 key购买 nike

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

最佳答案

为什么要为三个嵌套的 for 循环烦恼?你可以这样做

for (i=0; i<XMAX*YMAX*ZMAX; ++i)
{
sum += *(arr_ptr+i);
}

关于c++ - 迭代已知维度矩阵的最快方法,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/5046449/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com