您的位置:首页 > 编程语言 > C语言/C++

Lintcode 35.翻转链表

2017-12-13 16:41 387 查看
样例

给出一个链表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) {
if (head == NULL)
return NULL;
ListNode* t = NULL;
ListNode* p = head;
ListNode* q = head->next;
while (q != NULL)
{
p->next = t;
t = p;
p = q;
q = p->next;
}
p->next = t;
return p;
}
};想法:以前一直刷pat,第一次接触leetcode,lintcode这种平台,还没弄太明白,不过链表逆置算比较基本,三个指针完全可以应付,主要是找到循环结束点。
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签:  c++ 算法 链表 lintcode