前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >每天一算:Reverse Linked List

每天一算:Reverse Linked List

作者头像
五分钟学算法
发布2018-11-20 15:26:11
7530
发布2018-11-20 15:26:11
举报
文章被收录于专栏:五分钟学算法

LeetCode上第206号问题:Reverse Linked List

题目

反转一个单链表。 示例: 输入: 1->2->3->4->5->NULL 输出: 5->4->3->2->1->NULL 进阶: 你可以迭代或递归地反转链表。你能否用两种方法解决这道题?

解题思路

设置三个节点precurnext

  • (1)每次查看cur节点是否为NULL,如果是,则结束循环,获得结果
  • (2)如果cur节点不是为NULL,则先设置临时变量nextcur的下一个节点
  • (3)让cur的下一个节点变成指向pre,而后pre移动curcur移动到next
  • (4)重复(1)(2)(3)

动画演示

动画演示GIF有点大,请稍微等待一下加载显示^_^

动画演示

参考代码

1.迭代的方式处理
2.递归的方式处理
代码语言:javascript
复制
 1// 206. Reverse Linked List
 2// https://leetcode.com/problems/reverse-linked-list/description/
 3//
 4// 递归的方式反转链表
 5// 时间复杂度: O(n)
 6// 空间复杂度: O(1)
 7class Solution {
 8public:
 9    ListNode* reverseList(ListNode* head) {
10
11        // 递归终止条件
12        if(head == NULL || head->next == NULL)
13            return head;
14
15        ListNode* rhead = reverseList(head->next);
16
17        // head->next此刻指向head后面的链表的尾节点
18        // head->next->next = head把head节点放在了尾部
19        head->next->next = head;
20        head->next = NULL;
21
22        return rhead;
23    }
24};
本文参与 腾讯云自媒体同步曝光计划,分享自微信公众号。
原始发表:2018-11-09,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 五分钟学算法 微信公众号,前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 题目
  • 解题思路
  • 动画演示
  • 参考代码
    • 1.迭代的方式处理
      • 2.递归的方式处理
      领券
      问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档