剑指offer
输入一个链表,反转链表后,输出新链表的表头。
代码
代码如下:
/*
struct ListNode {
int val;
struct ListNode *next;
ListNode(int x) :
val(x), next(NULL) {
}
};*/
class Solution {
public:
ListNode* ReverseList(ListNode* pHead) {
if(pHead==nullptr||pHead->next==nullptr) return pHead;
ListNode* pbefore=nullptr;
ListNode* pnow=pHead;
ListNode* pafter=nullptr;
while(pnow!=nullptr){
pafter=pnow->next;
pnow->next=pbefore;
pbefore=pnow;
pnow=pafter;
}
return pbefore;
}
};