剑指Offer链表反转链表
Posted xiexinbei0318
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了剑指Offer链表反转链表相关的知识,希望对你有一定的参考价值。
题目:输入一个链表,反转链表后,输出新链表的表头。
A:定义3个结点,pNode作移动指针,pRet作输出指针,pPrev作前驱指针
在pNode没有到达链尾之前,循环里创建pNext指针记录pNode的后继结点
如果pNode为空,代表已经到了链尾,输出结果
其他:pNode的next指向pPrev,pPrev指向pNode,pNode指向pNext
/* struct ListNode int val; struct ListNode *next; ListNode(int x) : val(x), next(NULL) ;*/ class Solution public: ListNode* ReverseList(ListNode* pHead) if(pHead == nullptr) return nullptr; ListNode *pNode = pHead; ListNode *pPrev = nullptr; ListNode *pRet = nullptr; while(pNode != nullptr) ListNode *pNext = pNode->next; if(pNext == nullptr) pRet = pNode; pNode->next = pPrev; //精髓 pPrev = pNode; pNode = pNext; return pRet; ;
以上是关于剑指Offer链表反转链表的主要内容,如果未能解决你的问题,请参考以下文章