0

単純なデータファイル「matrix.dat」からデータを読み取っています。例:

1 2 3
4 5 6
7 8 9

ファイルを読み、データ ポイントを 2D 配列に保存します。

else /// Read data from file.
{
    // Check matrix is square and find number of columns/rows.
    n = CheckSquare(matrixData); /// n = dimension of square matrix
    fprintf(stdout, "n = %d\n", n); /// TESTING ///

    if(n != 0) /// Matrix is square.
    {
        int i, j; /// i = rows, j = columns.
        double MATRIX[n - 1][n - 1]; /// Declare 2D array of size n x n.

        // Loop through file "matrix.dat" and store data into 2D array "MATRIX".
        for(i = 0; i < n; i++) /// Loop rows.
        {
            for(j = 0; j < n; j++) /// Loop columns.
            {
                fscanf(matrixData, "%lf", &MATRIX[i][j]); /// Store data point as matrix element.
                fprintf(stdout, "[%d][%d] = %lf\n", i, j, MATRIX[i][j]); ///TESTING ///
            }
        }

        // Calculate the determinant of matrix "MATRIX".
        ///det = Determinant(n, MATRIX); /// COMMENT OUT ///
        ///fprintf(stdout, "Determinant = %lf\n", det); /// COMMENT OUT ///
        for(i = 0; i < n; i++) /// Loop rows.
        {
            for(j = 0; j < n; j++) /// Loop columns.
            {
                fprintf(stdout, "[%d][%d] = %lf\n", i, j, MATRIX[i][j]);
            }
        }
    }

テスト目的でマトリックスを 2 回出力していることがわかります。ファイルを読み取ってデータを保存しているときに1回、最初のforループが終了した後にもう一度。

2 つの for ループの間で 2D 配列 'MATRIX' を操作していないため、まったく同じ結果が出力されるはずです。

ただし、これは出力されるものです (上記のように「matrix.dat」ファイルを使用する場合):

n = 3
[0][0] = 1.000000
[0][1] = 2.000000
[0][2] = 3.000000
[1][0] = 4.000000
[1][1] = 5.000000
[1][2] = 6.000000
[2][0] = 7.000000
[2][1] = 8.000000
[2][2] = 9.000000

[0][0] = 1.000000
[0][1] = 2.000000
[0][2] = 4.000000
[1][0] = 4.000000
[1][1] = 5.000000
[1][2] = 5.000000
[2][0] = 5.000000
[2][1] = 8.000000
[2][2] = 9.000000

どんな助けでも大歓迎です。

念のため、これは「CheckSquare」関数です。

// Checks if matrix is square and returns the dimension if TRUE.
// Otherwise returns 0.
int CheckSquare(FILE* m)
{
    int dim; /// Dimension of matrix.
    int dataNum = 0; /// Holds number of data points in file "matrixData".
    double temp; /// Temporary variable to hold double data.

    // Check matrix is square and find number of columns/rows.
    while(fscanf(m, "%lf", &temp) != EOF) /// Data can still be read from file "matrixData".
    {
        dataNum++; /// Adds to number of data points.
    }
    rewind(m); /// Sets the position indicator to the beginning of the file "matrixData".

    dim = sqrt(dataNum); /// Number of columns and rows if 'dataNum' is perfect square.

    if(dim*dim == dataNum) /// Matrix is square.
    {
        return(dim);
    }

    else
    {
        return(0);
    }
}
4

1 に答える 1

2

n が 3 の場合、有効なインデックスは 0,1,2 ですが、行列を次のように宣言しています。

double MATRIX[n - 1][n - 1];

ただし、次のように宣言する必要があります。

double MATRIX[n][n];

次のようなループを使用している場合:

for(i = 0; i < n; i++) /// Loop rows.
{
    for(j = 0; j < n; j++) /// Loop columns.
    {

n == 3の場合、0、1、2を繰り返します。

于 2013-11-05T19:09:10.583 に答える