Problem A: 零起点学算法93——矩阵转置
Description
现要求你把一个矩阵行列转置后输出,注意行数和列数可能不相同的。
Input
多组测试数据,每组测试数据先在一行输入n 和m ,表示这个矩阵的行数和列数(1 < n,m <= 10) 然后是n行m列的一个矩阵
Output
对于每组测试数据输出转置后的矩阵
Sample Input
3 2
1 2
3 4
5 6
Sample Output
1 3 5
2 4 6
#include<stdio.h>
int main()
{
int n,a[20][20],b[20][20],i,j,m;
while(scanf("%d%d",&n,&m)!=EOF){
for(i=0;i<n;i++){
for(j=0;j<m;j++){
scanf("%d",&a[i][j]);
}
}
for(i=0;i<m;i++){
for(j=0;j<n;j++){
b[i][j]=a[j][i];
}
}
for(i=0;i<m;i++){
for(j=0;j<n-1;j++){
printf("%d ",b[i][j]);
}
printf("%d\n",b[i][n-1]);
}
}
return 0;
}
总结
1、对于二维数组常常嵌套二重for循环。
2、尤其注意输出的格式,常常最后一个和换行一起单独输出。
3、对于行和列的转置要注意对应关系。