【算法】反转链表

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

题目描述:

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

相关推荐
寂静山林3 小时前
UVa 10228 A Star not a Tree?
算法
Neverfadeaway3 小时前
【C语言】深入理解函数指针数组应用(4)
c语言·开发语言·算法·回调函数·转移表·c语言实现计算器
Madison-No74 小时前
【C++】探秘vector的底层实现
java·c++·算法
Swift社区4 小时前
LeetCode 401 - 二进制手表
算法·leetcode·ssh
派大星爱吃猫4 小时前
顺序表算法题(LeetCode)
算法·leetcode·职场和发展
liu****4 小时前
8.list的模拟实现
linux·数据结构·c++·算法·list
地平线开发者5 小时前
征程 6 | 征程 6 工具链如何支持 Matmul/Conv 双 int16 输入量化?
算法·自动驾驶
程序员大雄学编程6 小时前
「深度学习笔记4」深度学习优化算法完全指南:从梯度下降到Adam的实战详解
笔记·深度学习·算法·机器学习
小O的算法实验室6 小时前
2022年ASOC SCI2区TOP,基于竞争与合作策略的金字塔粒子群算法PPSO,深度解析+性能实测,深度解析+性能实测
算法·论文复现·智能算法·智能算法改进
武帝为此7 小时前
【B树与B+树详解】
数据结构·b树