原题链接:[编程入门]二维数组的转置
解题思路:声明两个数组a[3][3],b[3][3],后者存放转置后的元素。先用for循环嵌套输入a数组元素,接着(关键点)是转置:我们把二维数组看成矩阵,或者说坐标系,这样就很容易想到,行列互换就是横纵坐标对应的元素互换。用代码描述就是b[j][i]=a[i][j]。最后输出b数组就行了。
注意事项:输出b数组时不能把for循环嵌套这部分放到main函数中,不然会输出9个奇怪的数。因为,b数组作用域在自定义函数内。
还有,自定义函数中不要对数组a再定义,否则会重定义;也不要把数组b放到main函数中,不然自定义函数缺少数组b的声明。
参考代码:
#include<stdio.h>
void zhuanzhi(int a[3][3])
{
int b[3][3];
int i,j;
//转置
for(i=0; i<3; i++)
{
for(j=0; j<3; ++j)
{
b[j][i]=a[i][j];
}
}
//输出
for(i=0; i<3; i++)
{
for(j=0; j<3; j++)
{
printf("%d ", b[i][j]);
}
printf("\n");
}
}
int main()
{
int i,j;
int a[3][3];
//输入
for(i=0; i<3; i++)
{
for(j=0; j<3; ++j)
{
scanf("%d", &a[i][j]);
}
}
zhuanzhi(a);
return 0;
}0.0分
32 人评分
C语言网提供由在职研发工程师或ACM蓝桥杯竞赛优秀选手录制的视频教程,并配有习题和答疑,点击了解:
一点编程也不会写的:零基础C语言学练课程
解决困扰你多年的C语言疑难杂症特性的C语言进阶课程
从零到写出一个爬虫的Python编程课程
只会语法写不出代码?手把手带你写100个编程真题的编程百练课程
信息学奥赛或C++选手的 必学C++课程
蓝桥杯ACM、信息学奥赛的必学课程:算法竞赛课入门课程
手把手讲解近五年真题的蓝桥杯辅导课程
void TransposeArray(int buff[][3]) { for(int i = 0;i < 3;i++) { for(int j = 0; j < 3;j++) { if(j > i) { int temp = buff[i][j]; buff[i][j] = buff[j][i]; buff[j][i] = temp; } } } for(int i = 0;i < 3;i++) { for(int j = 0; j < 3;j++) { printf("%d " , buff[i][j]); } printf("\n"); } }#include <stdio.h> int main() { int syx[3][3]; int i,j; for(i=0;i<3;i++) { for(j=0;j<3;j++) { scanf("%d",&syx[i][j]); } } for(i=0;i<3;i++) { for(j=0;j<3;j++) { printf("%d ",syx[j][i]); } printf("\n"); } return 0; }#include<stdio.h> int main(){ int a[3][3],b[3][3],i,j; for(i=0;i<3;i++){ for(j=0;j<3;j++){ scanf("%d",&a[i][j]); } } for(i=0;i<3;i++){ for(j=0;j<3;j++){ b[j][i]=a[i][j]; } } for(j=0;j<3;j++){ for(i=0;i<3;i++){ printf("%d\t",b[j][i]); } printf("\n"); } return 0; }#include<stdio.h> #define a 3 #define b 3 int main() { void transform(int array[a][b]){ for(int i=0;i<a;i++){ for(int j=0;j<b;j++){ printf("%d ",array[j][i]); } printf("\n"); } } int array[a][b]; for(int i=0;i<a;i++){ for(int j=0;j<b;j++){ scanf("%d ",&array[i][j]); } } transform(array); return 0; }@小胖鸽 #include<stdio.h> int main() { int a[3][3]; for(int i=0;i<3;i++) { for(int j=0;j<3;j++) { scanf("%d",&a[i][j]); } } for(int i=0;i<3;i++) { for(int j=0;j<3;j++) { int temp=i; i=j; j=temp; printf("%d",a[i][j]); } printf(" "); } return 0; }