欢迎光临散文网 会员登陆 & 注册

矩阵乘法 的C程序实现1——数据结构与算法基础(青岛大学-王卓)绪论

2023-02-22 06:38 作者:阿勇往直前  | 我要投稿

#include<stdio.h>
#include<stdlib.h>

#define N 3
void initMatrix(int *,int ,int );
void mulMatrix(int*, int*,int*, int);
void showMatrix(int* a, int n);


int main()
{

    int a[N][N];
    int b[N][N];
    int c[N][N];

    initMatrix(a, N, 1);
    initMatrix(b, N, 5);
    mulMatrix(c, a, b, N);
    showMatrix(a, N);
    showMatrix(b, N);
    showMatrix(c, N);

    system("pause");
    return 0;
}

void initMatrix(int *a, int n,int starti)
{
    for (int i = 0; i < n; i++)
    {
        for (int j = 0; j < n; j++)
        {
            a[i*n+j] = starti + i + j;
        }
    }
}

void mulMatrix(int* c, int* a, int* b, int n)
{
    for (int i = 0; i < n; i++)
    {
        for (int j = 0; j < n; j++)
        {
            c[i * n + j] = 0;
            for (int k = 0; k < n; k++)
            {
                c[i * n + j] = c[i * n + j] + a[i * n + k] * b[k * n + j];
            }

        }
    }
}

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

矩阵乘法 的C程序实现1——数据结构与算法基础(青岛大学-王卓)绪论的评论 (共 条)

分享到微博请遵守国家法律