解题思路:简单反向输出不是真正的转置,同时题目要求用函数,最合理的办法是将数组首地址传进去
注意事项:这里的函数形参a[3][3],b[3][3]指的不是具体的数值,而是二维数组的首地址,所以在main函数使用中,实参是a,b。
b[3][3]在这里是输出,放在形参中是因为如果在函数中定义,局部变量在函数执行完后释放,没有办法再取到其中的值。
传址比传值剩下了复制时间和内存空间。
参考代码:
#include void mycase(int a[3][3],int b[3][3]) { for(int i=0;i<3;i++) { for(int j=0;j<3;j++) { b[i][j]=a[j][i]; } } } int main() { int a[3][3]; int b[3][3]; for(int i=0;i<3;i++) { for(int j=0;j<3;j++) { scanf("%d",&a[i][j]); } } mycase(a,b); for(int i=0;i<3;i++) { for(int j=0;j<3;j++) { printf("%d ",b[i][j]); } printf("\n"); } return 0; }
0.0分
1 人评分
校门外的树 (C语言代码)浏览:956 |
C语言程序设计教程(第三版)课后习题1.5 (C语言代码)浏览:481 |
C语言程序设计教程(第三版)课后习题1.5 (C语言代码)浏览:526 |
蛇行矩阵 (C语言代码)浏览:524 |
字符串输入输出函数 (C语言代码)浏览:2480 |
1071题解浏览:484 |
永远的丰碑 (C语言代码)浏览:516 |
分解质因数 (C++代码)浏览:1471 |
小O的乘积 (C++代码)浏览:747 |
C语言程序设计教程(第三版)课后习题7.5 (C语言代码)浏览:712 |