鱼C论坛

 找回密码
 立即注册
查看: 1556|回复: 9

C数组指针函数的问题

[复制链接]
发表于 2020-2-21 12:38:21 | 显示全部楼层 |阅读模式

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

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

x
转换10个数字的顺序,第一个程序正确,第二个就错了,只是子函数中j的位置变化了

程序1:

#include<stdio.h>
int main()
{
        void inv(int *a,int n);
        int a[10]={3,7,9,11,0,6,7,5,4,2},i;
        printf("The original array:\n");
        for(i=0;i<10;i++)
        {
                printf("%d,",a[i]);
        }
        printf("\n");
        inv(a,10);
        printf("The inverted array:\n");
        for(i=0;i<10;i++)
        {
                printf("%d,",a[i]);
        }
        printf("\n");
        return 0;
}

void inv(int *x,int n)
{
        int *i,*j,m,temp,*p;
        m=(n-1)/2;
        p=x+m;
        i=x;
        j=x+n-1;
        for(;i<=p;i++,j--)
        {
                temp=*i;
                *i=*j;
                *j=temp;       
        }
}

程序2:
//8.8 实参:数组   形参:指针变量
#include<stdio.h>
int main()
{
        void inv(int *a,int n);
        int a[10]={3,7,9,11,0,6,7,5,4,2},i;
        printf("The original array:\n");
        for(i=0;i<10;i++)
        {
                printf("%d,",a[i]);
        }
        inv(a,10);
        printf("\n");
        printf("The inverted array:\n");
        for(i=0;i<10;i++)
        {
                printf("%d,",a[i]);
        }
        printf("\n");
        return 0;
}

void inv(int *x,int n)
{
        int *i,*j,m,temp,*p;
        m=(n-1)/2;
        p=x+m;
        i=x;
//        j=x+n-1;
        for(;i<=p;i++)
        {
                j=x+n-1-i;                                //只有对j的处理不同
                temp=*i;
                *i=*j;
                *j=temp;       
        }
}
小甲鱼最新课程 -> https://ilovefishc.com
回复

使用道具 举报

发表于 2020-2-21 14:20:52 | 显示全部楼层
这是将0两端调换吗
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2020-2-21 14:36:45 | 显示全部楼层
第二个代码哪里多了个-i;
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2020-2-21 14:38:04 | 显示全部楼层
小甲鱼水里游 发表于 2020-2-21 14:36
第二个代码哪里多了个-i;

你改动那里,多了个-i,话说不明白你为什么要换一种方法
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2020-2-21 14:40:21 | 显示全部楼层
代码尽量规范才好,X建议改成arr或者array,i和j最好也用top和bottom来代替
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2020-2-21 19:43:48 | 显示全部楼层
小甲鱼水里游 发表于 2020-2-21 14:36
第二个代码哪里多了个-i;

j=x-1+n-i应该随着i也减1呀,取代了原来的j--
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2020-2-21 19:45:47 | 显示全部楼层

功能是让10个数按反向顺序存放,即结果应该为{2,4,5,7,6,0,11,9,7,3}
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2020-2-22 16:45:38 | 显示全部楼层
本帖最后由 major_lyu 于 2020-2-22 17:01 编辑

你第二个程序编译都通不过吧!!
  1. #include<stdio.h>
  2. void inv(int *x, int n);
  3. void inv2(int *x, int n);
  4. int main()
  5. {
  6.         //void inv(int *a,int n); //函数声明最好放在main函数外面;
  7.         int a[10]={3,7,9,11,0,6,7,5,4,2};
  8.         int i;
  9.         printf("The original array:\n");
  10.         for(i=0;i<10;i++)
  11.         {
  12.                 printf("%d,",a[i]);
  13.         }
  14.         printf("\n");
  15.         //inv(a,10);
  16.         inv2(a,10);
  17.         printf("The inverted array:\n");
  18.         for(i=0;i<10;i++)
  19.         {
  20.                 printf("%d,",a[i]);
  21.         }
  22.         printf("\n");
  23.         return 0;
  24. }

  25. void inv(int *x,int n)
  26. {
  27.         int *i,*j, *p;
  28.         int m,temp; // 指针变量和整型变量最好不要放在一行定义
  29.         m=(n-1)/2;
  30.         p=x+m;
  31.         i=x;
  32.         j=x+n-1;
  33.         for(;i<=p;i++,j--)
  34.         {
  35.                 temp=*i;
  36.                 *i=*j;
  37.                 *j=temp;      
  38.         }
  39. }
  40. void inv2(int *x,int n)
  41. {
  42.         int *i,*j,*p;
  43.         int m,temp;
  44.         m=(n-1)/2;
  45.         p=x+m;
  46.         i=x;
  47.         //j=x+n-1;
  48.         for(;i<=p;i++)
  49.         {
  50.                 //j=x+n-1-i; //只有对j的处理不同
  51.                 //(x+n-1)表示的数组第n-1个元素的地址,变量i是x第i个元素的地址.因此(x+n-1)减去指针值(i)得到的是一个偏移地址,偏移地址的类型是 long int;
  52.                 // 而变量j是一个int指针类型的变量,因此不能直接赋值
  53.                 j =x+n-1-(i-x); //这样才是正确的:(i-x)是第i个元素与数组起始地址的偏移地址,(x+n-1)是数组最后一个元素的地址;所以(x+n-1)-(i-x)是数组第n-1-i个元素的地址
  54.                 //           
  55.                 temp=*i;
  56.                 *i=*j;
  57.                 *j=temp;      
  58.         }
  59. }
复制代码


或者函数inv2可以这样写:

  1. void inv2(int *x,int n)
  2. {
  3.         int temp;
  4.         for(int k=0;k<=(n-1)/2;k++)
  5.         {
  6.                 temp=*(x+k);
  7.                 *(x+k)=*(x+n-1-k);
  8.                 *(x+n-1-k)=temp;      
  9.         }
  10. }
复制代码

小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 1 反对 0

使用道具 举报

 楼主| 发表于 2020-2-22 18:58:29 | 显示全部楼层
major_lyu 发表于 2020-2-22 16:45
你第二个程序编译都通不过吧!!

最佳答案,一定花了好长时间
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2020-2-22 20:08:58 | 显示全部楼层
王盛帅 发表于 2020-2-22 18:58
最佳答案,一定花了好长时间。

这个不需要多长时间,不是逻辑错误,是语法错误.编译器就可以告诉你哪里错了啊!
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

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

本版积分规则

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

GMT+8, 2025-7-7 17:33

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

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