LintCode 35. 翻转链表
问题描述
翻转一个链表
样例
给出一个链表1->2->3->null,这个翻转后的链表为3->2->1->null
问题分析
此题给出的是一个单向链表,需要将链表头尾翻转。需要事先判断链表是否为空。
代码
/**
* Definition of ListNode
*
* class ListNode {
* public:
* int val;
* ListNode *next;
*
* ListNode(int val) {
* this->val = val;
* this->next = NULL;
* }
* }
*/
class Solution {
public:
/*
* @param head: n
* @return: The new head of reversed linked list.
*/
ListNode * reverse(ListNode * head) {
// write your code here
if (head == NULL || head->next == NULL) return head;
ListNode * p = head;
ListNode * q = p->next;
ListNode * r = q->next;
while (q != NULL)
{
q->next = p;
p = q;
q = r;
if(r != NULL)
r = r->next;
}
head->next = NULL;
head = p;
return head;
}
};
代码思路
先判断链表是否为空或者只有一个元素,这两种情况是不需要将链表逆置的,接下来建立三个指针,从头依次往下,每个指针指向一个节点,根据代码画一下图就明了了。