三种不同函数原型求mxn阶矩阵的转置矩阵

编程入门 行业动态 更新时间:2024-10-16 00:25:57

三种不同函数原型求mxn阶<a href=https://www.elefans.com/category/jswz/34/1769510.html style=矩阵的转置矩阵"/>

三种不同函数原型求mxn阶矩阵的转置矩阵

        分别按如下函数原型编程计算并输出mxn阶矩阵的转置矩阵。其中,m和n的值由用户从键盘输入。已知m和n的值都不超过10。

  •         void Transpose(int a[][N],int at[][M],int m,int n);
  •         void Transpose(int (*a)[N],int (*at)[M],int m,int n);
  •         void Transpose(int *a,int *at,int m,int n);

        心得体会都在注释里了_(:з」∠)_

#include<stdio.h>
#define M 10
#define N 10
//void Transpose(int a[][N],int at[][M],int m,int n);//第一种方法,数组
//void Transpose(int (*a)[N],int (*at)[M],int m,int n);//第二种方法,行指针
void Transpose(int *a,int *at,int m,int n);//第三种方法,列指针
int main(void)
{int a[M][N];//一定要写明最多为10x10矩阵,不然就像我半天不知道错在哪了qwqint at[N][M];int n,m;printf("Input m:");scanf("%d",&m);printf("Input n:");scanf("%d",&n);printf("Input mxn matrix:\n");for(int i=0;i<m;i++){for(int j=0;j<n;j++)scanf("%d",&a[i][j]);}Transpose(*a,*at,m,n);//如果使用第三种列指针的方法,传参时必须写出*a、*at,其他两种写a即可return 0;
}
//第一种方法,向函数传递数组
/*void Transpose(int a[][N],int at[][M],int m,int n)
{int i,j;printf("转置后的矩阵:\n");for(i=0;i<n;i++)//先循环n,后循环m{for(j=0;j<m;j++){at[i][j] = a[j][i];//转置矩阵的行等于原矩阵的列printf("%d ",at[i][j]);}printf("\n");}
}*/
//第二种方法,函数形参为行指针
/*void Transpose(int (*a)[N],int (*at)[M],int m,int n)
{int i,j;printf("转置后的矩阵:\n");for(i=0;i<n;i++)//先循环n,后循环m{for(j=0;j<m;j++){*(*(at+i)+j) = a[j][i];printf("%d ",*(*(at+i)+j));//等价于at[j][i]}printf("\n");}
}*/
//第三种方法,函数形参为列指针
void Transpose(int *a,int *at,int m,int n)
{int i,j;printf("转置后的矩阵:\n");for(i=0;i<n;i++)//先循环n,再循环m{for(j=0;j<m;j++){at[i*M+j] = a[j*N+i];printf("%d ",at[i*M+j]);//不能等价于at[i][j],而且必须是i*M,不能是I*m}printf("\n");}
}

参考输入输出1,m>n

参考输入输出2,m<n

更多推荐

三种不同函数原型求mxn阶矩阵的转置矩阵

本文发布于:2024-02-26 09:18:37,感谢您对本站的认可!
本文链接:https://www.elefans.com/category/jswz/34/1702004.html
版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系,我们将在24小时内删除。
本文标签:矩阵   三种   原型   函数   mxn

发布评论

评论列表 (有 0 条评论)
草根站长

>www.elefans.com

编程频道|电子爱好者 - 技术资讯及电子产品介绍!