鱼C论坛

 找回密码
 立即注册
查看: 2941|回复: 1

为什么会报错

[复制链接]
发表于 2019-12-5 15:30:16 | 显示全部楼层 |阅读模式

马上注册,结交更多好友,享用更多功能^_^

您需要 登录 才可以下载或查看,没有账号?立即注册

x
本帖最后由 liyiqi 于 2019-12-5 15:45 编辑

#include<stdio.h>
void move(int *matrix);
int main()
{
        int a[3][3]={{1,2,3},{4,5,6},{7,8,9}};
        int i,j;
        printf("转置前\n");
        for(i=0;i<3;i++)
        {
                for(j=0;j<3;j++)
                {
                        printf("%3d",*(*(a+i)+j));
                }printf("\n");
         }
       
        move(a);
        printf("转置后\n");
        for(i=0;i<3;i++)
        {
                for(j=0;j<3;j++)
                {
                        printf("%3d",*(*(a+i)+j));
                }printf("\n");
         }
       
        return 0;
}
void move(int *matrix)
{
        int i,j;
       
        for(j=0;i<3;i++)
        {
                for(i=0;j<3;j++)
                {
                        printf("%3d",*(matrix+j*3+i));
                }printf("\n");
         }                
}在move(a)错了
小甲鱼最新课程 -> https://ilovefishc.com
回复

使用道具 举报

发表于 2019-12-5 15:52:46 | 显示全部楼层

回帖奖励 +10 鱼币

本帖最后由 jackz007 于 2019-12-5 16:13 编辑
  1. #include<stdio.h>

  2. void move(int (* matrix)[3])        // 被调用函数定义前置可以避免调用前的函数声明
  3. {
  4.         int i , j  , t                                                           ;
  5.         for(i = 0 ; i < 3 ; i ++) for(j = 0 ; j < i ; j ++) {
  6.                 t = *( *(matrix + i) + j)                                        ;
  7.                 *( *(matrix + i) + j) = *( *(matrix + j) + i)                    ;
  8.                 *( *(matrix + j) + i) = t                                        ;
  9.         }
  10. }

  11. int main()
  12. {
  13.         int a[3][3] = {{1 , 2 , 3} ,{4 , 5 , 6} ,{7 , 8 , 9}} , i , j            ;
  14.         printf("转置前\n")                                                       ;
  15.         for(i = 0 ; i < 3 ; i ++) {
  16.                 for(j = 0 ; j < 3 ; j ++) printf("%3d" , * ( * (a + i) + j))     ;
  17.                 printf("\n")                                                     ;
  18.         }
  19.         move(a)                                                                  ;
  20.         printf("转置后\n")                                                       ;
  21.         for(i = 0 ; i < 3 ; i ++) {
  22.                 for(j = 0 ; j < 3 ; j ++) printf("%3d" , * (* (a + i) + j))      ;
  23.                 printf("\n")                                                     ;
  24.         }
  25. }
复制代码

        编译运行实况:
  1. C:\Bin>g++ -o x x.c

  2. C:\Bin>x
  3. 转置前
  4.   1  2  3
  5.   4  5  6
  6.   7  8  9
  7. 转置后
  8.   1  4  7
  9.   2  5  8
  10.   3  6  9

  11. C:\Bin>
复制代码

        前面的代码数组元素一律采用指向数组的指针表达,如果用二维数组方式表达,会更加简单清楚。
  1. #include<stdio.h>

  2. void move(int matrix[][3])        // 被调用函数定义前置可以避免调用前的函数声明
  3. {
  4.         int i , j  , t                      ;
  5.         for(i = 0 ; i < 3 ; i ++) for(j = 0 ; j < i ; j ++) {
  6.                 t = matrix[i][j]            ;
  7.                 matrix[i][j] = matrix[j][i] ;
  8.                 matrix[j][i] = t            ;
  9.         }
  10. }

  11. int main()
  12. {
  13.         int a[3][3] = {{1 , 2 , 3} ,{4 , 5 , 6} ,{7 , 8 , 9}} , i , j ;
  14.         printf("转置前\n")                                            ;
  15.         for(i = 0 ; i < 3 ; i ++) {
  16.                 for(j = 0 ; j < 3 ; j ++) printf("%3d" , a[i][j])     ;
  17.                 printf("\n")                                          ;
  18.         }
  19.         move(a)                                                       ;
  20.         printf("转置后\n")                                            ;
  21.         for(i = 0 ; i < 3 ; i ++) {
  22.                 for(j = 0 ; j < 3 ; j ++) printf("%3d" , a[i][j])     ;
  23.                 printf("\n")                                          ;
  24.         }
  25. }
复制代码

        这份代码的编译和执行效果与前面完全一样。
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 1 反对 0

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

小黑屋|手机版|Archiver|鱼C工作室 ( 粤ICP备18085999号-1 | 粤公网安备 44051102000585号)

GMT+8, 2025-5-12 07:44

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

快速回复 返回顶部 返回列表