C语言 矩阵相加,数乘

现在来做一些现代里面的矩阵运算:

矩阵的加减运算,矩阵的数乘运算

/**
MatrixAddition.c
实现两个矩阵相加

*/
#include<stdio.h>
const int COLS=3;
void printMatirx(int *pArray,int rows,int cols);
void printMatirx2(int (*pArray)[COLS],int rows);
int main()
{
    int A[3][4]={{15,10,9,12},
                 {18,14,8,7},
                 {16,13,6,11}};
    printf("矩阵A=\n");
    printMatirx(A,3,4);
    int B[3][4]={{4,3,5,2},
                 {0,9,6,1},
                 {5,7,2,6}};
    printf("矩阵B=\n");
    printMatirx(B,3,4);
    int C[3][4];

    int i,j;
    //矩阵相加:两个矩阵必须行数和列数一样才能相加,
    //和矩阵的每个元素分别是两个矩阵对应的元素的和
    printf("矩阵A+矩阵B=\n");
    for(i=0;i<3;i++)//控制行
    {
        for(j=0;j<4;j++)
        {
            C[i][j]=A[i][j]+B[i][j];
//            printf("%3d",C[i][j]);//输出结果
        }
//        printf("\n");
    }
    int (*p)[COLS]=C;
    printMatirx2(p,3);
/*结果应为:
19 13 14 14
18 23 14  8
21 20  8 17
*/
    printf("矩阵C-矩阵A=\n");
    for(i=0;i<3;i++)//控制行
    {
        for(j=0;j<4;j++)
        {

            printf("%3d",C[i][j]-A[i][j]);//输出结果
        }
        printf("\n");
    }
    /*结果应为:
    4  3  5  2
    0  9  6  1
    5  7  2  6
    */
    //矩阵数乘:
    int D[3][4];
    printf("矩阵D:\n");
    for(i=0;i<3;i++)//控制行
    {
        for(j=0;j<4;j++)
        {
            D[i][j]=1;
            printf("%d\t", D[i][j]);//输出结果
        }
        printf("\n");
    }
    int mul;
    printf("矩阵D数乘以:");
    scanf("%d",&mul);
    printf("矩阵D数乘以%d=\n",mul);
    for(i=0;i<3;i++)//控制行
    {
        for(j=0;j<4;j++)
        {
            D[i][j]=D[i][j]*mul;
            printf("%d\t", D[i][j]);//输出结果
        }
        printf("\n");
    }
    return 0;
}
//使用一级指针来访问二维数组
void printMatirx(int *pArray,int rows,int cols)
{
    int i;
    int j;
    for(i=0;i<rows;i++)
    {
        for(j=0;j< cols;j++)
        {
            printf("%d\t",*(pArray+i*cols+j));
        }
        printf("\n");
    }
}
//使用指向一维数组的指针,访问二维数组
void printMatirx2(int (*pArray)[COLS],int rows)
{
    int i,j;
    for(i=0;i<rows;i++)
    {
        for(j=0;j<COLS;j++)
        {
            printf("%d\t",pArray[i][j]);
            /*
            []运算符的结合方向是由左向右,pArray[1][2]就等价于(* (pArray + 1))[2],
            而由于pArray是数组指针,而且数组的长度为3,
            所以* (pArray + 1):表示跨过3个元素,而也就是到array第二行
            即表示array[1]这个数组,则pArray[1][2]则就完全等价于array[1][2]。
            */
        }
        printf("\n");
    }
}
结果:

矩阵A=
15      10      9       12
18      14      8       7
16      13      6       11
矩阵B=
4       3       5       2
0       9       6       1
5       7       2       6
矩阵A+矩阵B=
19      13      14
14      18      23
14      8       21
矩阵C-矩阵A=
  4  3  5  2
  0  9  6  1
  5  7  2  6
矩阵D:
1       1       1       1
1       1       1       1
1       1       1       1
矩阵D数乘以:666
矩阵D数乘以666=
666     666     666     666
666     666     666     666
666     666     666     666

Process returned 0 (0x0)   execution time : 9.059 s
Press any key to continue.


根据引用,我们可以使用三元组顺序表来表示稀疏矩阵,并实现两个矩阵相加运算。具体步骤如下: 1. 首先输入两个矩阵的行数和列数,以及非零元素的个数。 2. 然后输入每个非零元素的行、列和值,分别存储在三元组顺序表中。 3. 对于两个矩阵相加运算,我们可以先将两个矩阵的三元组顺序表按照行和列的大小排序,然后依次比较每个非零元素的行和列,进行相应的加法运算。 4. 最后将结果矩阵以通常的阵列形式列出。 下面是一个示例代码,用于实现两个稀疏矩阵相加运算: ```c #include <stdio.h> #define MAXSIZE 100 typedef struct { int row; int col; int val; } Triple; typedef struct { Triple data[MAXSIZE + 1]; int rows, cols, nums; } TSMatrix; void CreateSMatrix(TSMatrix *M) { printf("请输入矩阵的行数、列数和非零元素的个数:\n"); scanf("%d%d%d", &M->rows, &M->cols, &M->nums); printf("请输入每个非零元素的行、列和值:\n"); for (int i = 1; i <= M->nums; i++) { scanf("%d%d%d", &M->data[i].row, &M->data[i].col, &M->data[i].val); } } void PrintSMatrix(TSMatrix M) { int k = 1; for (int i = 1; i <= M.rows; i++) { for (int j = 1; j <= M.cols; j++) { if (M.data[k].row == i && M.data[k].col == j) { printf("%d ", M.data[k].val); k++; } else { printf("0 "); } } printf("\n"); } } void AddSMatrix(TSMatrix M, TSMatrix N, TSMatrix *Q) { if (M.rows != N.rows || M.cols != N.cols) { printf("两个矩阵的行数或列数不相等,无法相加!\n"); return; } int i = 1, j = 1, k = 1; while (i <= M.nums && j <= N.nums) { if (M.data[i].row < N.data[j].row || (M.data[i].row == N.data[j].row && M.data[i].col < N.data[j].col)) { Q->data[k++] = M.data[i++]; } else if (M.data[i].row > N.data[j].row || (M.data[i].row == N.data[j].row && M.data[i].col > N.data[j].col)) { Q->data[k++] = N.data[j++]; } else { int sum = M.data[i].val + N.data[j].val; if (sum != 0) { Q->data[k].row = M.data[i].row; Q->data[k].col = M.data[i].col; Q->data[k].val = sum; k++; } i++; j++; } } while (i <= M.nums) { Q->data[k++] = M.data[i++]; } while (j <= N.nums) { Q->data[k++] = N.data[j++]; } Q->rows = M.rows; Q->cols = M.cols; Q->nums = k - 1; } int main() { TSMatrix M, N, Q; CreateSMatrix(&M); CreateSMatrix(&N); AddSMatrix(M, N, &Q); printf("矩阵M:\n"); PrintSMatrix(M); printf("矩阵N:\n"); PrintSMatrix(N); printf("矩阵M+N:\n"); PrintSMatrix(Q); return 0; } ```
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值