输入一个链表,反转链表后,输出新链表的表头。
- 思路1: 利用堆栈先进先出性质,但是内存过大
struct ListNode {
int val;
struct ListNode *next;
ListNode(int x) :
val(x), next(NULL) {
}
};
class Solution {
public:
ListNode* ReverseList(ListNode* pHead)
{
stack<ListNode*> st;
if(pHead == NULL) return NULL;
while(pHead->next != NULL)
{
st.push(pHead->next);
}
return st.top();
}
};
- 思路2: 遍历的时候翻转链表
/*
struct ListNode {
int val;
struct ListNode *next;
ListNode(int x) :
val(x), next(NULL) {
}
};*/
class Solution {
public:
ListNode* ReverseList(ListNode* pHead)
{
struct ListNode* pre = NULL;
struct ListNode* next = NULL;
if(pHead == NULL) return NULL;
while(pHead != NULL)
{
next = pHead->next;
pHead->next = pre;
pre = pHead;
pHead = next;
}
return pre;
}
};
更多原创技术分享 搜索公众号 柠檬的编程学堂