在此示例中,您將學習將兩個矩陣相乘并使用用戶定義的函數(shù)進行顯示。
要理解此示例,您應該了解以下C語言編程主題:
該程序要求用戶輸入兩個矩陣的大?。ㄐ泻土校?。
為了將兩個矩陣相乘,第一個矩陣的列數(shù)應等于第二個矩陣的行數(shù)。
下面的程序要求兩個矩陣的行數(shù)和列數(shù),直到滿足上述條件。
然后,執(zhí)行兩個矩陣的相乘,結果顯示在屏幕上。
為此,我們創(chuàng)建了三個函數(shù):
enterData() - 從用戶那里獲取矩陣元素。
multiplyMatrices() - 將兩個矩陣相乘。
display() - 在乘法后顯示結果矩陣。
#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");
}
}
}輸出結果
輸入第一個矩陣的行和列: 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