题目描述
输入一个链表,反转链表后,输出新链表的表头。
完整代码
借助栈来实现
/*
struct ListNode {
int val;
struct ListNode *next;
ListNode(int x) :
val(x), next(NULL) {
}
};*/
class Solution {
public:
ListNode* ReverseList(ListNode* pHead) {
//借助栈实现链表的反转
stack<int> num;
ListNode* p;
p=pHead;
while(p){
num.push(p->val);
p=p->next;
}
p=pHead;
while(p){
p->val=num.top();
num.pop();
p=p->next;
}
return pHead;
}
};
直接反转指针
/*
struct ListNode {
int val;
struct ListNode *next;
ListNode(int x) :
val(x), next(NULL) {
}
};*/
class Solution {
public:
ListNode* ReverseList(ListNode* pHead) {
//原来p->next,指向next,现在让其指向pre
ListNode* p,*pre,*nextt;
pre=NULL;
p=pHead;
while(p){
nextt=p->next;
p->next=pre;//反转指针
pre=p;
p=nextt;
}
return pre;
}
};