用指向一维数组的指针变量即二维数组的行指针作为函数参数,实现矩阵转置。
按如下函数原型编程计算并输出m×n阶矩阵的转置矩阵。
其中,m和n的值由用户从键盘输入。已知m和n的值都不超过10。
void Transpose(int (*a)[N], int (*at)[M], int m, int n);
void InputMatrix(int (*a)[N], int m, int n);
void PrintMatrix(int (at)[M], int n, int m);
输入提示信息:“Input m, n:”
输入格式:"%d,%d"
输入提示信息:"Input %d%d matrix:\n"
输出提示信息和格式:“The transposed matrix is:\n”
输出格式:"%d\t"
程序源码
#include<stdio.h>
#define M 10
#define N 10
void Transpose(int (*a)[N], int (*at)[M], int m, int n);
void InputMatrix(int (*a)[N], int m, int n);
void PrintMatrix(int (*at)[M], int n, int m);
int main()
{
int s[M][N],st[N][M],m,n;// 1 2 3 4 5 6 7 8 9
printf("Input m, n:");
scanf("%d,%d",&m,&n);
InputMatrix(s,m,n);
Transpose(s,st,m,n);
printf("The transposed matrix is:\n");
PrintMatrix(st,n,m);
return 0;
}
void Transpose(int (*a)[N], int (*at)[M], int m, int n)
{
int i,j;
for(i=0; i<m; i++)
for(j=0; j<n; j++)
*(*(at+j)+i)=*(*(a+i)+j);
}
void InputMatrix(int (*a)[N], int m, int n)
{
int i,j;
printf("Input %d*%d matrix:\n",m,n);
for(i=0; i<m; i++)
for(j=0; j<n; j++)
scanf("%d",*(a+i)+j);
}
void PrintMatrix(int (*at)[M], int n, int m)
{
int i,j;
for(i=0; i<n; i++)
{
for(j=0; j<m; j++)
printf("%3d",*(*(at+i)+j));
printf("\n");
}
}