数组排序问题,萌新求教
#include<stdio.h>int main(void)
{
int i,j;
int k,a={0},*p=a;
printf("please input a:\n");
for(i=0;i<15;i++)
{
scanf("%d", &k);
for(j=0;j<i&&k<*(p+j);j++);
if(j<i) for(int b=i; b>j; b--) *(p+b)=*(p+b-1);
*(p+j)=k;
}
printf("%d",a);
for(i=1;i<15;i++)
printf("%3d", *(p+i));
printf("\n");
return 0;
}
b--处,当i=1时,经过b--,那么p+b-1不是等于-1吗?这是为什么呢? 本帖最后由 jackz007 于 2022-11-27 10:18 编辑
这是我写的代码啊:https://fishc.com.cn/forum.php?mod=redirect&goto=findpost&ptid=220764&pid=6050207
i = 1 时,* (p + b - 1) = * (p)执行完这一句后,才是 b --,b = 0,b > j 肯定不满足(因为,j 肯定不可能是一个负数),所以,就不会有* (p + b - 1) = * (p - 1) 了。
页:
[1]