问题描述
描述
一个矩阵,想知道转置后的矩阵(将矩阵的行列互换得到的新矩阵称为转置矩阵),请编程解答。
输入描述:
第一行包含两个整数n和m,表示一个矩阵包含n行m列,用空格分隔。 (1≤n≤10,1≤m≤10)
从2到n+1行,每行输入m个整数(范围-231~231-1),用空格分隔,共输入n*m个数,表示第一个矩阵中的元素。
输出描述:
输出m行n列,为矩阵转置后的结果。每个数后面有一个空格。
示例1
输入:
2 3
1 2 3
4 5 6
输出:
1 4
2 5
3 6
问题分析
这是一个数组差异化输入输出得问题。
解决方案
输入一套规则,输出一套规则。
代码
#include <stdio.h>
int main()
{
int n=0, m=0;
while (scanf("%d %d", &n, &m) != EOF)
{
int arr[10][10]={0};
for(int i=0;i<n;i++)
for(int j=0;j<m;j++)
{
scanf("%d",&arr[i][j]);
}
for(int j=0;j<m;j++)
{
for(int i=0;i<n;i++)
{
printf("%d ",arr[i][j]);
}
printf("\n");
}
}
return 0;
}