Tsukinai的第五十五个程序
按如下函数原型编程计算并输出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"
#include <stdio.h>
#include <string.h>
#include <stdlib.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 a[N][N];
int n;
printf("Input n:");
scanf("%d", &n);
printf("Input %d*%d matrix:\n", n, n);
InputMatrix(a, n);
Transpose(a, n);
puts("The transposed matrix is:");
PrintMatrix(a, n);
system("pause");
return 0;
}
void Swap(int *x, int *y)
{
int temp;
temp = *x;
*x = *y;
*y = temp;
}
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 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;
}
}
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");
}
}