搜索
编程论坛
→
开发语言
→
『 C语言论坛 』
→ 求助 C算法实现带头节点链表的数据节点部分逆序
标题:
求助 C算法实现带头节点链表的数据节点部分逆序
只看楼主
giant611
等 级:
新手上路
帖 子:43
专家分:0
注 册:2007-9-25
楼主
问题点数:0 回复次数:4
求助 C算法实现带头节点链表的数据节点部分逆序
void reverse(*h)
{
*p,*q; //////////就是两个跟h同类型的指针,具体没写出来
p=h->next;
h->next=NULL;
while(p!=NULL)
{
q=p;
p=p->next;
q->next=h->next;
h->next=q;
}
}
谁能详细分析哈,本人还有点迷糊,感觉不是那么回事
搜索更多相关主题的帖子:
链表
逆序
节点
算法
next
2007-12-05 13:17
静思
来 自:沈阳
等 级:
新手上路
威 望:
8
帖 子:630
专家分:0
注 册:2006-2-28
第
2
楼
得分:0
void reverse(*h)
{
*p,*q; //////////就是两个跟h同类型的指针,具体没写出来
p=h->next;//p指向第一个节点,保存链表后序位置
h->next=NULL;//
while(p!=NULL)
{
q=p;//q保存当前节点位置
p=p->next;//p指向下个节点
q->next=h->next;//这句和下面一句头插法重新组织链表,使链表倒序
h->next=q;
}
}
楼主自己动动手画下图就清楚了
英者自知,雄者自胜
2007-12-05 13:54
zbqf109
等 级:
新手上路
帖 子:289
专家分:0
注 册:2006-12-31
第
3
楼
得分:0
嗯,链表的操作如果想不清楚,在纸上用笔画一画就明白了。
还有,如果逆序,建议只去改变节点内容,不要改变指针指向的地址。一来这不是必须的;二来改变指针指向的地址把操作复杂化了,而且容易出错。
坚决不跟用TC的人打交道!
2007-12-05 14:25
giant611
等 级:
新手上路
帖 子:43
专家分:0
注 册:2007-9-25
第
4
楼
得分:0
回复 3# 的帖子
谢谢你的提示,照你的意思,就相当于把节点关键字重新倒叙就行了呗,指针不用管
2007-12-05 20:41
giant611
等 级:
新手上路
帖 子:43
专家分:0
注 册:2007-9-25
第
5
楼
得分:0
回复 2# 的帖子
谢谢了
2007-12-05 20:46
5
1/1页
1
参与讨论请移步原网站贴子:
https://bbs.bccn.net/thread-190531-1-1.html
关于我们
|
广告合作
|
编程中国
|
清除Cookies
|
TOP
|
手机版
编程中国
版权所有,并保留所有权利。
Powered by
Discuz
, Processed in 0.514692 second(s), 8 queries.
Copyright©2004-2025, BCCN.NET, All Rights Reserved