首页 > 其他 > 详细

单链表逆序

时间:2018-05-31 01:08:47      阅读:229      评论:0      收藏:0      [点我收藏+]

  最近经常碰到让写链表逆序的命题,但是我总是粗心大意漏掉内容,造成结果是痛苦和迷茫:

 1 void SWapNow(Node* p)
 2 {
 3     Node* pCur = p->pNext;
 4     p->pNext = NULL;
 5     Node* pTemp = NULL;
 6     Node* pPre = NULL;
 7     while (NULL != pCur)
 8     {
 9         pPre = p->pNext;
10         p->pNext = pCur;
11         pTemp = pCur->pNext;
12         pCur->pNext = pPre;
13         pCur = pTemp;
14     }
15 }

  如上代码,为头插法,第4行内容没有的话,链表在第一节点陷入死循环,造成空间不足的bug;

  如上代码主要是先保存头部连接的下一节点,置换为当前节点,保存当前节点的下一节点,置换为头部节点的前下一节点。之后利用保存的当前节点的下一节点进行循环置换。

  挺简单的,但是当时怎么也理不清道不明,唉,考菜说的就是我这种人吧!

单链表逆序

原文:https://www.cnblogs.com/WaterGood/p/9114160.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!