ListNode* ReverseList(ListNode* pHead) {
if (pHead->next == NULL || pHead == NULL) return pHead;
ListNode* pReversedHead = NULL;
ListNode* pNode = pHead;
ListNode* pPrev = NULL;
while (pNode != NULL) {
ListNode* pNext = pNode->next;
if (pNext == NULL) {
pReversedHead = pNode;
}
pNode->next = pPrev;
pPrev = pNode;
pNode = pNext;
}
return pReversedHead;
}
主要的三个指针:
1.指向前,当前位置,后的指针