1

Visual Studio がこのコードを (メッセージの最後で) うまくコンパイルするのに、g++ でエラーが発生する理由を教えてください。

chapter8_1.cpp:97:50: error: macro "minor" passed 3 arguments, but takes just 1
chapter8_1.cpp:136:36: error: macro "minor" passed 3 arguments, but takes just 1
chapter8_1.cpp:97:11: error: function definition does not declare parameters
chapter8_1.cpp: In member function ‘double Matrices::determinant(double**, int)’:
chapter8_1.cpp:136:17: error: ‘minor’ was not declared in this scope

現在、これらの 2 つの関数は にありますがstruct、no (単に独立した関数) でコンパイルするとstruct、g++ でエラーが発生せず、プログラムは正常に動作します。このプログラムは、正方行列の行列式を計算することを目的としていました。

コード:

struct Matrices
{  
.......

    double **minor(double **matrix, int dim, int row)  // row stands for the number of column that we are expanding by
    {
        int dim2 =--dim;
        double **minor2;
        minor2=new double*[dim2];                            // creates minor matrix 
        for(int i=0; i<dim2; ++i)
            minor2[i]=new double[dim2];

        for(int hhh=0; hhh<dim2; ++hhh)
            {   
                int bbb=0;
                for(int aaa=0; aaa<dim2+1; ++aaa)                  // initializing the minor matrix
                    {

                    if (aaa==row)
                        continue;
                    else
                        {
                            minor2[hhh][bbb]=matrix[hhh+1][aaa];
                            ++bbb;
                        }
                    }
                }
        return minor2;
    }

    double determinant(double **mat, int dim)
    { 
    double det=0;
    if(dim==1)
    det=mat[0][0];
    if(dim==2)
    det=mat[0][0]*mat[1][1]-mat[0][1]*mat[1][0];
    else
    {
    double ***setOFmat;                                      // pointer that points to minors
    setOFmat=new double**[dim];
    for (int ddd=0; ddd<dim; ++ddd)                         // ddd represents here the number of column we are expanding by
        setOFmat[ddd]=minor(mat, dim, ddd);
    for (int ddd=0; ddd<dim; ++ddd)                         // ddd srepresents the same here
    {

        det= det + pow(-1.0,ddd)*mat[0][ddd]*determinant(setOFmat[ddd], dim-1);    // actual formula that calculates the determinant

    }
    }
    return det;
    }
4

1 に答える 1