在此示例中,您將學(xué)習(xí)將兩個矩陣相乘并使用用戶定義的函數(shù)進行顯示。
要理解此示例,您應(yīng)該了解以下C語言編程主題:
該程序要求用戶輸入兩個矩陣的大?。ㄐ泻土校?/p>
為了將兩個矩陣相乘,第一個矩陣的列數(shù)應(yīng)等于第二個矩陣的行數(shù)。
下面的程序要求兩個矩陣的行數(shù)和列數(shù),直到滿足上述條件。
然后,執(zhí)行兩個矩陣的相乘,結(jié)果顯示在屏幕上。
為此,我們創(chuàng)建了三個函數(shù):
enterData() - 從用戶那里獲取矩陣元素。
multiplyMatrices() - 將兩個矩陣相乘。
display() - 在乘法后顯示結(jié)果矩陣。
#include <stdio.h> void enterData(int first[][10], int second[][10], int r1, int c1, int r2, int c2); void multiplyMatrices(int first[][10], int second[][10], int multResult[][10], int r1, int c1, int r2, int c2); void display(int mult[][10], int r1, int c2); int main() { int first[10][10], second[10][10], mult[10][10], r1, c1, r2, c2; printf("輸入第一個矩陣的行和列: "); scanf("%d %d", &r1, &c1); printf("輸入第二個矩陣的行和列: "); scanf("%d %d", &r2, &c2); //進行輸入直到第一個矩陣的列等于第二個矩陣的行 while (c1 != r2) { printf("錯誤! 再次輸入行和列。\n"); printf("輸入第一個矩陣的行和列: "); scanf("%d%d", &r1, &c1); printf("輸入第二個矩陣的行和列: "); scanf("%d%d", &r2, &c2); } //取得矩陣數(shù)據(jù)的函數(shù) enterData(first, second, r1, c1, r2, c2); //用于將兩個矩陣相乘的函數(shù)。 multiplyMatrices(first, second, mult, r1, c1, r2, c2); //顯示相乘后的合成矩陣的函數(shù)。 display(mult, r1, c2); return 0; } void enterData(int first[][10], int second[][10], int r1, int c1, int r2, int c2) { printf("\n輸入矩陣元素 1:\n"); for (int i = 0; i < r1; ++i) { for (int j = 0; j < c1; ++j) { printf("Enter a%d%d: ", i + 1, j + 1); scanf("%d", &first[i][j]); } } printf("\n輸入矩陣元素 2:\n"); for (int i = 0; i < r2; ++i) { for (int j = 0; j < c2; ++j) { printf("Enter b%d%d: ", i + 1, j + 1); scanf("%d", &second[i][j]); } } } void multiplyMatrices(int first[][10], int second[][10], int mult[][10], int r1, int c1, int r2, int c2) { // 矩陣的初始化元素多為0。 for (int i = 0; i < r1; ++i) { for (int j = 0; j < c2; ++j) { mult[i][j] = 0; } } // 第一矩陣和第二矩陣相乘并存儲在mult中。 for (int i = 0; i < r1; ++i) { for (int j = 0; j < c2; ++j) { for (int k = 0; k < c1; ++k) { mult[i][j] += first[i][k] * second[k][j]; } } } } void display(int mult[][10], int r1, int c2) { printf("\n輸出矩陣:\n"); for (int i = 0; i < r1; ++i) { for (int j = 0; j < c2; ++j) { printf("%d ", mult[i][j]); if (j == c2 - 1) printf("\n"); } } }
輸出結(jié)果
輸入第一個矩陣的行和列: 2 3 輸入第二個矩陣的行和列: 3 2 輸入矩陣元素 1: Enter a11: 3 Enter a12: -2 Enter a13: 5 Enter a21: 3 Enter a22: 0 Enter a23: 4 輸入矩陣元素 2: Enter b11: 2 Enter b12: 3 Enter b21: -9 Enter b22: 0 Enter b31: 0 Enter b32: 4 輸出矩陣: 24 29 6 25