Latepossible 2020-12-22 18:12 采纳率: 100%
浏览 11
已采纳

想知道我的算法哪里出错了,输出来一堆奇怪的数字。

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

int M=3;
int MatMult(int a[3][3], int b[3][3]);
int main(void)
{	
	int a[3][3]={{ 1, 2, 3 },{ 2, 3, 1 },{ 3, 1, 2 }};
	int b[3][3]={{ 1, 0, 0 },{ 0, 1, 0 }, { 0, 0, 1 }};
	
	MatMult(a,b);	
 } 
 
int MatMult(int a[3][3], int b[3][3])
{
	int C[3][3];
	int D[3][3];
	int i,j,k;
	for(i=0;i<M;i++)
   {
	  for(j=0;j<M;j++)
	  {
	    for(k=0;k<M;k++)
		{
			C[j][k]=a[i][k] * b[k][j];
		    D[i][j]+=C[j][k];
			}	
	  }
	}	
	
	
	for(i=0;i<M;i++)
   {
	  for(j=0;j<M;j++)
	  {
	  	 printf("%d",D[i][j]);
	  	 printf("\n");
      }
    }
	return 1;
	
	 
}
  • 写回答

1条回答 默认 最新

  • 泡视界 2020-12-22 19:41
    关注

    你是不是要实现矩阵乘的运算?

    算法没错,缺少了D[i][j]的初始化,所以是一堆很大或者很小的数字。

    for (i = 0; i < M; i++)
    {
        for (j = 0; j < M; j++)
        {
    	D[i][j] = 0;    //初始化
    	for (k = 0; k < M; k++)
            {
                C[j][k] = a[i][k] * b[k][j];
                D[i][j] += C[j][k];
            }
        }
    }

    以上

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论

报告相同问题?

悬赏问题

  • ¥50 请教 麒麟系统挂载怎么安装
  • ¥15 如何在ns3中实现路径的自由切换
  • ¥20 SpringBoot+Vue3
  • ¥15 IT从业者的调查问卷
  • ¥65 LineageOs-21.0系统编译问题
  • ¥30 关于#c++#的问题,请各位专家解答!
  • ¥15 App的会员连续扣费
  • ¥15 不同数据类型的特征融合应该怎么做
  • ¥15 用proteus软件设计一个基于8086微处理器的简易温度计
  • ¥15 用联想小新14Pro