按如下函数原型编程计算并输出n×n阶矩阵的转置矩阵。其中,n由用户从键盘输入。已知n值不超过10。
void Transpose(int (*a)[N], int n);
void Swap(int *x, int *y);
void InputMatrix(int (a)[N], int n);
void PrintMatrix(int (a)[N], int n);
输入提示信息:“Input n:”
输入格式:"%d"
输入提示信息:"Input %d%d matrix:\n"
输出提示信息:“The transposed matrix is:\n”
输出格式:"%d\t"
程序运行示例:
Input n:3
Input 33 matrix:
8 5 2
4 2 6
8 6 2
The transposed matrix is:
8 4 8
5 2 6
2 6 2
#include<studio.h>
#define N 10
void Transpose(int (*a)[N], int n);
void Swap(int *x, int *y);
void InputMatrix(int (*a)[N], int n);
void PrintMatrix(int (*a)[N], int n);
int main()
{
int n;
int a[N][N];
printf("Input n:");
scanf("%d",&n);
printf("Input %d*%d matrix:\n",n,n);
InputMatrix(a,n);
Transpose(a,n);
printf("The transposed matrix is:\n");
PrintMatrix(a,n);
return 0;
}
void InputMatrix(int (*a)[N], int n)
{
int i,j;
for(i=0;i<n;i++)
{
for(j=0;j<n;j++)
{
scanf("%d",*(a+i)+j);
}
}
}
void PrintMatrix(int (*a)[N], int n)
{
int i,j;
for(i=0;i<n;i++)
{
for(j=0;j<n;j++)
{
printf("%d\t",*(*(a+i)+j));
}
printf("\n");
}
}
void Swap(int *x, int *y)
{
int temp;
temp=*x;
*x=*y;
*y=temp;
}
void Transpose(int (*a)[N], int n)
{
int i,j,k=0;
for(i=0;i<n;i++)
{
for(j=k;j<n;j++)
{
Swap(*(a+i)+j,*(a+j)+i);
}
k++;//?
}
}