标题:谁能解释一下这段程序,关于链表的逆转
取消只看楼主
xilixjd
Rank: 1
等 级:新手上路
帖 子:11
专家分:9
注 册:2015-12-6
结帖率:100%
 问题点数:0 回复次数:0 
谁能解释一下这段程序,关于链表的逆转
程序代码:
void ReverseList(LinkList H)
/*逆置链表*/
{
    ListNode *p,*q;
    p=H->next;        /*p指向链表的第一个结点*/
    H->next=NULL;
    while(p)        /*利用头插法将结点依次插入到链表的头部*/
    {
        q=p->next;
        p->next=H->next;
        H->next=p;
        p=q;
    }
}

如果之前让头结点断裂H->next=NULL,那么接下来p->next=H->next不就=NULL?
自己画了图觉得这个程序完全不着边际。。但是运行起来又是对的。
2015-12-24 19:37



参与讨论请移步原网站贴子:https://bbs.bccn.net/thread-460540-1-1.html




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

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