题目描述:
输入一个链表,反转链表后,输出新链表的表头。
说明:本题目包含复杂数据结构ListNode,点此查看相关信息
/*
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* nextNode = pHead;
//单节点
if(nextNode == nullptr)
return nullptr;
//一般情况
ListNode* tempNode = nullptr;
while(pHead != nullptr)
{
nextNode = pHead->next;
pHead->next = tempNode;
tempNode = pHead;
pHead = nextNode;
}
return tempNode;
}
};