c语言结点按升序排列,【求助ing】关于结构体中的节点的排列问题,改了好久还是不成功...

这篇博客探讨了一段C语言代码,该代码旨在通过指针操作对结构体节点按`num`成员进行升序排列。作者遇到了代码逻辑问题,导致排序未成功。博客内容包括了对双层循环的解释,以及尝试修复排序错误的过程。

该楼层疑似违规已被系统折叠 隐藏此楼查看此楼

就是传递一个指向结构体的指针

里面有很多节点

按各各节点的num成员的大小进行升序排列

每个节点都有num和*next成员

struct tagTWO *insert(struct tagTWO *head)

{

struct tagTWO *p1,*p2,*prv1,*prv2,*temp,*tempprv;

/*p1用于外层循环,p2用于内层循环,prv1指向p1的前一个,prv2指向p2的前一个*/

/*temp和tempprv用于保存含有最小num值的节点和它的前一个节点*/

for(p1=prv1=temp=head; p1->next != NULL; prv1=p1,p1=p1->next,temp=p1)

/*初始化让temp*/ /*这里改了可以正常输出但是没有升序排列*/

{

for(prv2=p1,p2=prv2->next; p2 != NULL; prv2=p2,p2=p2->next)

if(temp->num > p2->num)/*内层循环获得num值为最小的那个节点*/

{

temp=p2;

tempprv=prv2;/*把p2和prv2暂时赋给temp和tempprv*/

}

if(temp != p1) /*如果temp改变了*/

{

p2=temp->next;/*暂时让p2指向temp的next*/

if(p1==head && temp->next==NULL) /*如果p1为头而且temp的next为NULL*/

{

head=temp;temp->next=p1;tempprv->next=NULL;

/*让temp插到p1前面,让tempprv的next等于NULL*/

}

else

{

if(p1==head)/*如果只是p1为头*/

{

tempprv->next=p2;head=temp;temp->next=p1;

/*让tempprv的next指向temp的下一个*/

}

else if(temp->next==NULL) /*如果只是temp的next指向尾*/

{

prv1->next=temp;temp->next=p1;tempprv->next=NULL;

}

else if(p1!=head && temp->next!=NULL) /*p1不为头且temp的next不为尾*/

{

tempprv->next=p2;prv1->next=temp;temp->next=p1;

/*tempprv的next指向temp的后一个也就是删除temp*/

/*然后让temp插入prv1和p1之间*/

}

}

}

}

return(head);

}

又改了一下,可以正常输出,但是没用按照目的升序排列。。。

看来我的debug能力太菜�

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值