题目描述:
输入一个链表,反转链表后,输出新链表的表头。
题目分析:
方法一:利用栈先进后出的特性,将单链表逆置;
方法二:利用指针,将单链表原地逆置;
代码实现:
/*
struct ListNode {
int val;
struct ListNode *next;
ListNode(int x) :
val(x), next(NULL) {
}
};*/
class Solution {
public:
//原地逆置单链表
ListNode* ReverseList(ListNode* pHead)
{
ListNode* h = pHead;//中间结点指针
ListNode* p = NULL; //后一个结点指针
ListNode* q = NULL; //前一个结点指针
while(h != NULL)
{
p = h->next; //保存头指针的后一个结点地址
h->next = q; //向头指针的next指针指向前一个元素(第一次为空,最后一个结点指向空)
if(p == NULL) //只有一个结点
{
break;
}
q = h; //保存头指针地址
h = p; //头指针后移一个节点
}
return h;
}
};