【算法】反转链表

本题来源---《反转链表

题目描述:

给你单链表的头节点 head ,请你反转链表,并返回反转后的链表。

示例 1:

复制代码
输入:head = [1,2,3,4,5]
输出:[5,4,3,2,1]

示例 2:

复制代码
输入:head = [1,2]
输出:[2,1]

示例 3:

复制代码
输入:head = []
输出:[]

提示:

  • 链表中节点的数目范围是 [0, 5000]

  • -5000 <= Node.val <= 5000

    /**

    • Definition for singly-linked list.
    • struct ListNode {
    • 复制代码
      int val;
    • 复制代码
      struct ListNode *next;
    • };
      /
      struct ListNode
      reverseList(struct ListNode* head)
      {

    }

关于本题如何实现反转链表,我总结以下两种方法:

第一种:迭代法

第二种:递归法

第一种:迭代法

解题思路:(以实例1为例)

(1)保存当前节点的下一个节点指针next。

(2)将cur->next指向prev 。

(3)更新prev指针为当前节点。

(4) 更新当前节点为下一个节点。

代码如下:

复制代码
struct ListNode* reverseList(struct ListNode* head) 
{
    struct ListNode     *prev = NULL;
    struct ListNode     *cur  = head;
    struct ListNode     *next = NULL;

    while( cur )
    {
        next = cur->next;
        cur->next = prev;
        prev = cur;
        cur = next;
    }   

    return prev;
}

复杂度:

时间复杂度:O(n)

空间复杂度:O(1)

第二种:递归法

解题思路:

代码如下:

复制代码
struct ListNode* reverseList(struct ListNode* head) 
{
    if( !head || !head->next )
    {
        return head;
    }

    struct ListNode *res = reverseList( head->next );

    head->next->next = head;
    head->next = NULL;

    return res;
}

复杂度:

时间复杂度:O(n)

空间复杂度:O(n)

相关推荐
qq_4298796733 分钟前
省略号和可变参数模板
开发语言·c++·算法
飞川撸码2 小时前
【LeetCode 热题100】网格路径类 DP 系列题:不同路径 & 最小路径和(力扣62 / 64 )(Go语言版)
算法·leetcode·golang·动态规划
Neil今天也要学习2 小时前
永磁同步电机参数辨识算法--IPMSM拓展卡尔曼滤波全参数辨识
单片机·嵌入式硬件·算法
yzx9910133 小时前
基于 Q-Learning 算法和 CNN 的强化学习实现方案
人工智能·算法·cnn
亮亮爱刷题3 小时前
算法练习-回溯
算法
眼镜哥(with glasses)4 小时前
蓝桥杯 国赛2024python(b组)题目(1-3)
数据结构·算法·蓝桥杯
int型码农8 小时前
数据结构第八章(一) 插入排序
c语言·数据结构·算法·排序算法·希尔排序
UFIT8 小时前
NoSQL之redis哨兵
java·前端·算法
喜欢吃燃面8 小时前
C++刷题:日期模拟(1)
c++·学习·算法
SHERlocked938 小时前
CPP 从 0 到 1 完成一个支持 future/promise 的 Windows 异步串口通信库
c++·算法·promise