C数组指针函数的问题
转换10个数字的顺序,第一个程序正确,第二个就错了,只是子函数中j的位置变化了程序1:
#include<stdio.h>
int main()
{
void inv(int *a,int n);
int a={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);
}
printf("\n");
inv(a,10);
printf("The inverted array:\n");
for(i=0;i<10;i++)
{
printf("%d,",a);
}
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={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);
}
inv(a,10);
printf("\n");
printf("The inverted array:\n");
for(i=0;i<10;i++)
{
printf("%d,",a);
}
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;
}
} 这是将0两端调换吗 第二个代码哪里多了个-i; 小甲鱼水里游 发表于 2020-2-21 14:36
第二个代码哪里多了个-i;
你改动那里,多了个-i,话说不明白你为什么要换一种方法 代码尽量规范才好,X建议改成arr或者array,i和j最好也用top和bottom来代替 小甲鱼水里游 发表于 2020-2-21 14:36
第二个代码哪里多了个-i;
j=x-1+n-i应该随着i也减1呀,取代了原来的j-- 小甲鱼水里游 发表于 2020-2-21 14:20
这是将0两端调换吗
功能是让10个数按反向顺序存放,即结果应该为{2,4,5,7,6,0,11,9,7,3} 本帖最后由 major_lyu 于 2020-2-22 17:01 编辑
你第二个程序编译都通不过吧!!
#include<stdio.h>
void inv(int *x, int n);
void inv2(int *x, int n);
int main()
{
//void inv(int *a,int n); //函数声明最好放在main函数外面;
int a={3,7,9,11,0,6,7,5,4,2};
int i;
printf("The original array:\n");
for(i=0;i<10;i++)
{
printf("%d,",a);
}
printf("\n");
//inv(a,10);
inv2(a,10);
printf("The inverted array:\n");
for(i=0;i<10;i++)
{
printf("%d,",a);
}
printf("\n");
return 0;
}
void inv(int *x,int n)
{
int *i,*j, *p;
int m,temp; // 指针变量和整型变量最好不要放在一行定义
m=(n-1)/2;
p=x+m;
i=x;
j=x+n-1;
for(;i<=p;i++,j--)
{
temp=*i;
*i=*j;
*j=temp;
}
}
void inv2(int *x,int n)
{
int *i,*j,*p;
int m,temp;
m=(n-1)/2;
p=x+m;
i=x;
//j=x+n-1;
for(;i<=p;i++)
{
//j=x+n-1-i; //只有对j的处理不同
//(x+n-1)表示的数组第n-1个元素的地址,变量i是x第i个元素的地址.因此(x+n-1)减去指针值(i)得到的是一个偏移地址,偏移地址的类型是 long int;
// 而变量j是一个int指针类型的变量,因此不能直接赋值
j =x+n-1-(i-x); //这样才是正确的:(i-x)是第i个元素与数组起始地址的偏移地址,(x+n-1)是数组最后一个元素的地址;所以(x+n-1)-(i-x)是数组第n-1-i个元素的地址
//
temp=*i;
*i=*j;
*j=temp;
}
}
或者函数inv2可以这样写:
void inv2(int *x,int n)
{
int temp;
for(int k=0;k<=(n-1)/2;k++)
{
temp=*(x+k);
*(x+k)=*(x+n-1-k);
*(x+n-1-k)=temp;
}
}
major_lyu 发表于 2020-2-22 16:45
你第二个程序编译都通不过吧!!
最佳答案,一定花了好长时间{:10_298:}。 王盛帅 发表于 2020-2-22 18:58
最佳答案,一定花了好长时间。
这个不需要多长时间,不是逻辑错误,是语法错误.编译器就可以告诉你哪里错了啊!
页:
[1]