C语言 动态生成矩阵,并实现其录入转置



 #include <stdio.h>
#include <stdlib.h>
bool check(int row1,int col1,int row2,int col2);
int *Multiplication(int *arr1,int *arr2,int row1,int col1,int row2,int col2);
int main()
{
	int row1=1,col1=1,row2=1,col2=1;
	int i,j;
	//检查相乘矩阵的有效性
label:
	printf("请输入要输入的两个矩阵的行数列数:\n");
	printf("第一个矩阵的行数列数:");
	scanf("%d%d",&row1,&col1);
	printf("第二个矩阵的行数列数:");
	scanf("%d%d",&row2,&col2);

	if(check(row1,col1,row2,col2))
	{
			//第一个矩阵数据的录入
		printf("请输入第一个矩阵的数据:\n");
		int *myarr1=(int *)malloc(row1*col1*sizeof(int));
		for(i=0;i<row1;i++)
		{
			for(j=0;j<col1;j++)
			{
				scanf("%d",myarr1+col1*i+j);
			}
		}
			//第二个矩阵数据的录入
		printf("请输入第二个矩阵的数据:\n");
		int *myarr2=(int *)malloc(row2*col2*sizeof(int));
		for(i=0;i<row2;i++)
		{
			for(j=0;j<col2;j++)
			{
				scanf("%d",myarr2+col2*i+j);
			}
		}
		//两个矩阵的显示
		printf("两个矩阵的数据分别为:\n");
		for(i=0;i<row1;i++)
		{
			for(j=0;j<col1;j++)
			{
				printf("%3d",*(myarr1+i*col1+j));
			}
			printf("\n");
		}
		for(i=0;i<row2;i++)
		{
			for(j=0;j<col2;j++)
			{
				printf("%3d",*(myarr2+i*col2+j));
			}
			printf("\n");
		}
		//计算两个矩阵相乘的结果并显示
		int *result=Multiplication(myarr1,myarr2,row1,col1,row2,col2);
		printf("矩阵相乘的结果矩阵为:\n");
		for(i=0;i<row1;i++)
		{
			for(j=0;j<col2;j++)
			{
				printf("%3d",*(result+i*col2+j));
			}
			printf("\n");
		}
	//	for()
	}
	else
	{
		printf("所输入的两个矩阵不可以相乘\n请重新输入:\n");
		goto label;
	}
	system("pause");
	return 0;
}
bool check(int row1,int col1,int row2,int col2)
{
	//printf("row1=%d,col1=%d,row2=%d,col2=%d\n",row1,col1,row2,col2);
	if(row1>0||row2>0||col1>0||col2>0)
	{
		if(col1==row2)
			return true;
		else
			return false;
	}
	else
	{
		return false;
	}
}
int *Multiplication(int *arr1,int *arr2,int row1,int col1,int row2,int col2)
{
	int *tempt=(int *)malloc(row1*col2*sizeof(int));
	for(int i=0;i<row1;i++)
	{
		for(int j=0;j<col2;j++)
		{
			int sum=0;
			for(int a=0;a<col1;a++)
			{
				sum=sum+ (*(arr1+i*col1+a)) * (*(arr2+a*col2+j));
			}
			*(tempt+i*col2+j)=sum;
		}
	}
	return tempt;
}


  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值