| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 1170 人关注过本帖
标题:求助 C算法实现带头节点链表的数据节点部分逆序
只看楼主 加入收藏
giant611
Rank: 1
等 级:新手上路
帖 子: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
静思
Rank: 3Rank: 3
来 自:沈阳
等 级:新手上路
威 望:8
帖 子:630
专家分:0
注 册:2006-2-28
收藏
得分: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
Rank: 1
等 级:新手上路
帖 子:289
专家分:0
注 册:2006-12-31
收藏
得分:0 
嗯,链表的操作如果想不清楚,在纸上用笔画一画就明白了。
还有,如果逆序,建议只去改变节点内容,不要改变指针指向的地址。一来这不是必须的;二来改变指针指向的地址把操作复杂化了,而且容易出错。

坚决不跟用TC的人打交道!
2007-12-05 14:25
giant611
Rank: 1
等 级:新手上路
帖 子:43
专家分:0
注 册:2007-9-25
收藏
得分:0 
回复 3# 的帖子
谢谢你的提示,照你的意思,就相当于把节点关键字重新倒叙就行了呗,指针不用管
2007-12-05 20:41
giant611
Rank: 1
等 级:新手上路
帖 子:43
专家分:0
注 册:2007-9-25
收藏
得分:0 
回复 2# 的帖子
谢谢了
2007-12-05 20:46
快速回复:求助 C算法实现带头节点链表的数据节点部分逆序
数据加载中...
 
   



关于我们 | 广告合作 | 编程中国 | 清除Cookies | TOP | 手机版

编程中国 版权所有,并保留所有权利。
Powered by Discuz, Processed in 0.015962 second(s), 7 queries.
Copyright©2004-2024, BCCN.NET, All Rights Reserved