吾爱破解 - 52pojie.cn

 找回密码
 注册[Register]

QQ登录

只需一步,快速开始

查看: 1311|回复: 5
收起左侧

[求助] C语言矩阵乘法的问题

[复制链接]
雷欧库珀 发表于 2021-1-3 10:30
实现矩阵相乘算法
设 A 为 m * p 的矩阵,B 为 p * n 的矩阵,那么称 m * n 的矩阵 C 为矩阵 A 与 B 的乘积,记作 C = AB,其中矩阵 C 中的第 i 行第 j 列元素可以表示为
用户输入矩阵a和b,计算出矩阵 C
#include <stdio.h>
#include <stdlib.h>
int main()
{
//获得矩阵尺寸
int m,p,n;
printf("输入第一个矩阵尺寸:%d*%d\n",&m,&p);
printf("输入第二个矩阵尺寸:%d*%d\n",&p,&n);
int a[m][p];
int b[p][n];
//初始化存放乘积的矩阵
int c[m][n];
for(int i=0;i<m;i++)
{
    for (int j=0;j<n;j++)
    {
        c[i][j]=0;
    }
}

//获取矩阵具体值
printf("输入第一个矩阵:");
for (int i=0;i<m;i++)
{
        for (int j=0;j<p;j++)
        {
            scanf("%d",&a[i][j]);
        }
}
//获取第二个矩阵
printf("输入第二个矩阵:");
for (int i=0;i<p;i++)
{
        for (int j=0;j<n;j++)
        {
            scanf("%d",&b[i][j]);
        }
}
//计算乘积
    int i, j, k, row;
    for (i = 0; i < m; i++)
    {
        for (j = 0; j < n; j++)
        {
            for (k = 0; k < p; k++)
            {
                c[i][j] += a[i][k] * b[k][j];
            }
        }
    }

    // row 取行数最大值
    row = m > p ? m : p;

    for (i = 0; i < row; i++)
    {
        // 打印A
        printf("|  ");
        for (j = 0; j < p; j++)
        {
            if (i < m)
            {
                printf("\b%d ", a[i][j]);
                printf("|");
            }
            else
            {
                printf("\b\b\b     ");
            }
        }
        // 打印 * 号
        if (i == row / 2)
        {
            printf(" * ");
        }
        else
        {
            printf("   ");
        }
        printf("|  ");
        // 打印B
        for (j = 0; j < n; j++)
        {
            if (i < p)
            {
                printf("\b%d ", b[i][j]);
                printf("|");
            }
            else
            {
                printf("\b\b\b     ");
            }
        }
        // 打印 = 号
        if (i == row / 2)
        {
            printf(" = ");
        }
        else
        {
            printf("   ");
        }
        // 打印C
        printf("|  ");
        for (j = 0; j < n; j++)
        {
            if (i < m)
            {
                printf("\b%d ", c[i][j]);
                printf("|");
            }
            else
            {
                printf("\b\b\b      ");
            }
        }
        printf("\n");
    }
    system("pause");
    return 0;
}
这到底是我的程序有问题还是咋了?怎么解决?
我没有null指针

我的问题

我的问题
010546x1vzhh6uiu7fg3uv.jpg

发帖前要善用论坛搜索功能,那里可能会有你要找的答案或者已经有人发布过相同内容了,请勿重复发帖。

 楼主| 雷欧库珀 发表于 2021-1-3 10:34
a,我printf没改,解决了
糖糖小可爱 发表于 2021-1-3 10:43
初始化矩阵的时候有问题,应该是不能这么定义一个不明确大小的数组,胡乱说说,也不知道对不对
梦爱 发表于 2021-1-3 12:31
黑夜·执魔 发表于 2021-1-3 15:06
printf()你自己让它输出了,改成scanf()
xiaohanzhu 发表于 2021-1-3 17:47
printf()改成scnaf()
不然就随机数了
当然就直接输出了
其实不求速度的话
用c++会快很多(写起来)
您需要登录后才可以回帖 登录 | 注册[Register]

本版积分规则

返回列表

RSS订阅|小黑屋|处罚记录|联系我们|吾爱破解 - LCG - LSG ( 京ICP备16042023号 | 京公网安备 11010502030087号 )

GMT+8, 2024-11-26 10:41

Powered by Discuz!

Copyright © 2001-2020, Tencent Cloud.

快速回复 返回顶部 返回列表