题目:输入一个链表,反转链表后,输出新链表的表头。
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; } };
原文地址:https://www.cnblogs.com/xiexinbei0318/p/11426767.html
时间: 2024-10-09 14:09:21