5

2 つの 3x3 行列を乗算しようとしています。1 行目と 2 行目の最初の 2 つの数字のみが正解です。私は何を間違っていますか?必要なものは で宣言されていmult_matricesますか?

#include <stdio.h>

void mult_matrices(int a[][3], int b[][3], int result[][3]);
void print_matrix(int a[][3]);

int main()
{
    int p[3][3] = {{1, 2, 3},{4, 5, 6}, {7, 8, 9}};
    int q[3][3] = {{10, 11, 12}, {13, 14, 15}, {16, 17, 18}};
    int r[3][3];

    mult_matrices(p, q, r);
    print_matrix(r);
}

void mult_matrices(int a[][3], int b[][3], int result[][3])
{
    int i, j, k;
    for(i = 0; i < 3; i++)
    {
            for(j = 0; j < 3; j++)
            {
                    for(k = 0; k < 3; k++)
                    {
                            result[i][j] +=  a[i][k] *  b[k][j];
                    }
            }
    }
}

void print_matrix(int a[][3])
{
    int i, j;
    for (i = 0; i < 3; i++)
    {
            for(j = 0; j < 3; j++)
            {
                    printf("%d\t", a[i][j]);
            }
            printf("\n");
    }
 }
4

4 に答える 4

8

r使用する前に、必ずすべてゼロに初期化してください。

int r[3][3] = { 0 };
于 2011-04-14T22:51:43.123 に答える
7

resultマトリックスを初期化していないようです。

すなわち変更:

int r[3][3];

int r[3][3] ={{0,0,0},{0,0,0},{0,0,0}};
于 2011-04-14T22:51:25.150 に答える
4

私が気付いていないことの1つは、r[3][3]配列を初期化することです。これがあなたの問題の根源であるかどうかはわかりませんが、それは非常にうまくいく可能性があります。基本的に、rの値が設定されるのは、その場所のメモリに「残された」ものです。すべてが0になることもありますが、そうでない可能性があります。ですから、それはあなたが抱えている問題かもしれませんが、そうでない場合でも、常にすべての変数を初期化する習慣を身につけるのは良いことです。

于 2011-04-14T22:55:21.313 に答える