大矩阵计算

时间:2011-10-03 14:48:01

标签: c++

我用C ++编写一个简单的代码,然后在linux ubuntu 11.04上用g ++编译它,我没有得到任何错误但是当我运行可执行文件时,我得到了这个错误“seg fault”。

我知道我的代码没有问题,而且这个错误与编译器有关。

有人能帮助我吗?

我的代码是:

#include <math.h>
int main()
{
    double a[200][200][200],b[200][200][200],c[200][200][200];
    int i,j,k;

    double const pi=3.14;

    for(k=0;k<200;k++)
    {
        for(j=0;j<200;j++)
        {
            for(i=0;i<200;i++)
            {
                a[i][j][k]=sin(1.5*pi*i)*cos(3.5*pi*j)*k;
                b[i][j][k]=cos(1.5*pi*i)*cos(2.5*pi*k)*j;
                c[i][j][k]=a[i][j][k]-b[i][j][k];
            }
        }
    }
}

5 个答案:

答案 0 :(得分:13)

这三个阵列需要大约190MB的空间,这几乎肯定超过了操作系统强加的堆栈大小限制。

尝试在堆上分配它们(使用new),而不是将它们放在堆栈上。

答案 1 :(得分:2)

你将大量的double数组放入堆栈(假设你的架构是如何处理局部变量的)。几乎可以肯定,你的系统堆栈不能容纳那么多空间。

相反,使用向量代替在堆上分配:

std::vector<std::vector<std::vector<double> > > a(200, std::vector<std::vector<double> >(200, std::vector<double>(200)));

答案 2 :(得分:1)

堆栈溢出 - &gt;分段错误

答案 3 :(得分:1)

对于非对称的情况,我们必须使用它:

    double*** a=new double**[IE];
    for(int i=0;i<IE;i++){
        a[i]=new double *[JE];
        for(int j=0;j<JE;j++){
            a[i][j]=new double [KE];
        }
    }

使用上面的代码,我们可以构建巨大的矩阵,因为我们的计算机的ram允许。

答案 4 :(得分:1)

此功能可以帮助您:

double ***alloc3d(int l, int m, int n) {
    double *data = new double [l*m*n];
    double ***array = new double **[l];
    for (int i=0; i<l; i++) {
        array[i] = new double *[m];
        for (int j=0; j<m; j++) {
            array[i][j] = &(data[(i*m+j)*n]);
        }
    }

    return array;
}