鱼C论坛

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

[已解决]数组排序问题,萌新求教

[复制链接]
发表于 2022-11-27 08:42:09 | 显示全部楼层 |阅读模式

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

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

x
#include<stdio.h>
int main(void)
{
    int i,j;
    int k,a[15]={0},*p=a;
    printf("please input a[15]:\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[0]);
    for(i=1;i<15;i++)
    printf("%3d", *(p+i));
    printf("\n");
    return 0;
}



b--处,当i=1时,经过b--,那么p+b-1不是等于-1吗?这是为什么呢?
最佳答案
2022-11-27 09:59:11
本帖最后由 jackz007 于 2022-11-27 10:18 编辑

       这是我写的代码啊:https://fishc.com.cn/forum.php?m ... 764&pid=6050207

       i = 1 时,* (p + b - 1) = * (p)  执行完这一句后,才是 b --,b = 0,b > j 肯定不满足(因为,j 肯定不可能是一个负数),所以,就不会有  * (p + b - 1) = * (p - 1) 了。
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

发表于 2022-11-27 09:59:11 | 显示全部楼层    本楼为最佳答案   
本帖最后由 jackz007 于 2022-11-27 10:18 编辑

       这是我写的代码啊:https://fishc.com.cn/forum.php?m ... 764&pid=6050207

       i = 1 时,* (p + b - 1) = * (p)  执行完这一句后,才是 b --,b = 0,b > j 肯定不满足(因为,j 肯定不可能是一个负数),所以,就不会有  * (p + b - 1) = * (p - 1) 了。
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

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

本版积分规则

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

GMT+8, 2024-11-10 19:35

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

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