【算法】反转链表

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

题目描述:

给你单链表的头节点 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)

相关推荐
~|Bernard|22 分钟前
在 PyCharm 里怎么“点鼠标”完成指令同样的运行操作
算法·conda
战术摸鱼大师24 分钟前
电机控制(四)-级联PID控制器与参数整定(MATLAB&Simulink)
算法·matlab·运动控制·电机控制
Christo327 分钟前
TFS-2018《On the convergence of the sparse possibilistic c-means algorithm》
人工智能·算法·机器学习·数据挖掘
好家伙VCC1 小时前
数学建模模型 全网最全 数学建模常见算法汇总 含代码分析讲解
大数据·嵌入式硬件·算法·数学建模
liulilittle3 小时前
IP校验和算法:从网络协议到SIMD深度优化
网络·c++·网络协议·tcp/ip·算法·ip·通信
bkspiderx5 小时前
C++经典的数据结构与算法之经典算法思想:贪心算法(Greedy)
数据结构·c++·算法·贪心算法
中华小当家呐6 小时前
算法之常见八大排序
数据结构·算法·排序算法
沐怡旸6 小时前
【算法--链表】114.二叉树展开为链表--通俗讲解
算法·面试
tju新生代魔迷7 小时前
数据结构:双向链表
数据结构·链表
一只懒洋洋7 小时前
K-meas 聚类、KNN算法、决策树、随机森林
算法·决策树·聚类