day4-反转链表

反转链表

力扣题目链接

题目描述

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

思路

面试常考的题型,这里带来两种做法,一种双指针,一种迭代法。

双指针法

第一次看到题目时,我第一时间想到的是,先从第一个结点找到最后一个,然后再依次翻转。但是这样的时间复杂度就是O(2n)了。

为什么不能第一次遍历的时候就处理好所有翻转呢?定义两个指针

  • pre:指向当前结点的前一个结点
  • cur:指向当前结点

这样这需要一对对处理即可,难点在于如何进行结点的更替。

代码如下:

c 复制代码
class Solution {
public:
    ListNode* reverseList(ListNode* head) {
       ListNode* tmp;
       ListNode* cur = head;
       ListNode* pre = nullptr; //头节点的pre指向null

       while(cur){
            tmp = cur->next; //保存cur的下一个结点,因为下一步要修改
            cur->next = pre;
            //update
            pre = cur; // 更新结点,从后往前更新
            cur = tmp;
       }
       return pre;
    }
};
  • 时间复杂度:O(n)
  • 空间复杂度:O(1)

迭代法

迭代法的本质思路其实跟双指针是一样的,不同点在于使用了n栈的空间。

如果可以理解双指针,理解迭代法应该是更加轻松才对。

代码如下:

c 复制代码
 ListNode* reverseList(ListNode* head) {
        return reverse(nullptr,head);
    }
    ListNode* reverse(ListNode* pre, ListNode* cur)
    {
        if(cur == nullptr)return pre; //终止条件
        ListNode* tmp = cur->next;
        cur->next = pre;
        return reverse(cur,tmp);
    }
  • 时间复杂度:O(n)
  • 空间复杂度:O(n)
相关推荐
如何原谅奋力过但无声1 小时前
【灵神高频面试题合集06-08】反转链表、快慢指针(环形链表/重排链表)、前后指针(删除链表/链表去重)
数据结构·python·算法·leetcode·链表
平行侠1 小时前
037插入排序 - 整理扑克牌的算法
数据结构·算法
,,?!,4 小时前
数据结构算法-排序算法
数据结构·算法·排序算法
‎ദ്ദിᵔ.˛.ᵔ₎5 小时前
C++哈希表
数据结构·c++·散列表
阿旭超级学得完6 小时前
C++11(初始化)
java·开发语言·数据结构·c++·算法
云淡风轻~窗明几净6 小时前
关于角谷猜想的五行小猜想
数据结构·算法
Languorous.6 小时前
C++数据结构进阶|并查集(Union-Find)详解:从原理到面试实战
数据结构·c++·面试
Languorous.6 小时前
C++数据结构进阶|堆(Heap)详解:从手写实现到面试高频实战
数据结构·c++·面试
玛卡巴卡ldf7 小时前
【LeetCode 手撕算法】(栈)有效括号、最小栈、字符串解码、每日温度、柱状图最大矩形
java·数据结构·算法·leetcode·力扣
_深海凉_7 小时前
LeetCode热题100-两两交换链表中的节点
算法·leetcode·链表