LeeCode 19: 删除链表的倒数第n个节点

题目描述:

给你一个链表,删除链表的倒数第 n 个节点,并返回链表的头节点。

标签:链表,双指针

时间复杂度:O(N)

建立模型:

  1. 定义虚拟头节点,使其 next 指向 head
  2. 定义快慢指针 fast,slow,slow指向虚拟头节点,fast指向第 n 个节点
  3. 同时移动 fast,slow,直至 fast 到达链表尾部
  4. 此时 slow 的 next 域指向的节点即是要删除的节点
  5. 删除 slow.next,并返回虚拟头节点的 next 域

定义虚拟头节点的目的是便于将头节点与其它节点一样处理,无需额外讨论。

代码实现:

# Python3 实现
def removeNthFromEnd(self, head: ListNode, n: int) -> ListNode:
virtualHead = ListNode(0, head)
slow, fast = virtualHead, virtualHead for _ in range(n):
fast = fast.next while fast.next:
slow, fast = slow,next, fast.next slow.next = slow.next.next
return virtualHead.next
// Java 实现
public ListNode removeNthFromEnd(ListNode head, int n) {
ListNode virtualHead = new ListNode(0, head);
ListNode fast = virtualHead;
ListNode slow = virtualHead; while (n > 0) {
fast = fast.next;
n -= 1;
} while (fast.next != null) {
fast = fast.next;
slow = slow.next;
} slow.next = slow.next.next;
return virtualHead.next;
}

LeeCode 02.07: 链表相交

题目描述:

给你两个单链表的头节点 headAheadB ,请你找出并返回两个单链表相交的起始节点。如果两个链表没有交点,则返回 null

标签:链表,双指针

时间复杂度:O(M+N)

建立模型:

  1. 假设链表 headA 长度为a,链表 headB 长度为b,链表相交长度为c
  2. 遍历完 headA 再遍历 headB,到起始公共节点,共经过 a + (b - c + 1) 个节点
  3. 遍历完 headB 再遍历 headA,到起始公共节点,共经过 b + (a - c + 1) 个节点
  4. 若 c = 0,即不存在公共节点,则当前节点 a,b 均指向 Null
  5. 若 c > 0,即存在公共节点,则当前节点 a,b 指向起始公共节点

代码实现:

# Python3 实现
def getIntersectionNode(self, headA: ListNode, headB: ListNode) -> ListNode:
a, b = headA, headB
# a == b 存在两种情况
# 1. a = null, b = null, 即两指针均将 headA 和 headB 遍历完也没有相遇
# 2. a = c1, b = c1, 即两指针遍历过程中在链表相交起始节点相遇 while a != b:
a = a.next if a else headB
b = b.next if b else headA
return a
// Java 实现
public ListNode getIntersectionNode(ListNode headA, ListNode headB) {
ListNode a = headA;
ListNode b = headB;
while (a != b) {
a = (a == null ? headB : a.next);
b = (b == null ? headA : b.next);
} return a
}

LeeCode 142: 环形链表 II

题目描述:

给你一个链表的头节点 head ,返回链表开始入环的第一个节点,如果链表无环则返回 null

标签:链表,双指针

时间复杂度:O(N)

建立模型:

  1. 设 链表头部到环之前有 a 个节点, 链表环内有 b 个节点

  2. 定义快慢指针 fast, slow ,fast每次走两步,slow每次走一步

  3. 若 fast 走到链表尾部,则说明链表无环 return null

  4. 若 fast 与 slow 相遇,则 fast 与 slow 走过的路程关系有:

    \[\begin{cases}
    fast = 2 * slow \\
    fast - slow = n * b
    \end{cases}

    \qquad
    \Rightarrow
    \qquad

    \begin{cases}
    fast = 2 * n * b \\
    slow = n * b
    \end{cases}
    \]

  5. 且 slow 指针每次走到链表环的第一个节点时步数表达式为:\(slow = a + n * b\)

  6. 所以 slow 与 fast 相遇后再走 a 步即可到达链表环的第一个节点

  7. 如何确定 a 呢?

  8. 将 fast 指针重新指向 head,head 走 a 步也到达链表环的第一个节点,即同时移动 fast 和 slow,直至其第二次相遇

代码实现:

# Python 3实现
def detectCycle(self, head: ListNode) -> ListNode:
slow, fast = head, head
while fast and fast.next:
slow = slow.next
fast = fast.next.next if slow == fast:
break
if not (fast and fast.next):
return None fast = head
while fast != slow:
slow, fast = slow.next, fast.next return slow
// Java 实现
public ListNode detectCycle(ListNode head) {
ListNode slow = head;
ListNode fast = head;
while (fast != null && fast.next != null) {
slow = slow.next;
fast = fast.next.next; if (slow == fast) {
break;
}
} if (fast == null || fast.next == null) {
return null;
} fast = head;
while (slow != fast) {
slow = slow.next;
fast = fast.next;
} return slow;
}

LeeCode链表问题(二)的更多相关文章

  1. [LeetCode] Convert Sorted List to Binary Search Tree 将有序链表转为二叉搜索树

    Given a singly linked list where elements are sorted in ascending order, convert it to a height bala ...

  2. [LeetCode] Reverse Linked List II 倒置链表之二

    Reverse a linked list from position m to n. Do it in-place and in one-pass. For example:Given 1-> ...

  3. LeetCode(109):有序链表转换二叉搜索树

    Medium! 题目描述: 给定一个单链表,其中的元素按升序排序,将其转换为高度平衡的二叉搜索树. 本题中,一个高度平衡二叉树是指一个二叉树每个节点 的左右两个子树的高度差的绝对值不超过 1. 示例: ...

  4. LeetCode109. 有序链表转换二叉搜索树

    109. 有序链表转换二叉搜索树 问题描述 给定一个单链表,其中的元素按升序排序,将其转换为高度平衡的二叉搜索树. 本题中,一个高度平衡二叉树是指一个二叉树每个节点 的左右两个子树的高度差的绝对值不超 ...

  5. [LeetCode] 92. Reverse Linked List II 倒置链表之二

    Reverse a linked list from position m to n. Do it in one-pass. Note: 1 ≤ m ≤ n ≤ length of list. Exa ...

  6. Java实现 LeetCode 109 有序链表转换二叉搜索树

    109. 有序链表转换二叉搜索树 给定一个单链表,其中的元素按升序排序,将其转换为高度平衡的二叉搜索树. 本题中,一个高度平衡二叉树是指一个二叉树每个节点 的左右两个子树的高度差的绝对值不超过 1. ...

  7. [LeetCode 109] - 将已排序链表转换为二叉搜索树 (Convert Sorted List to Binary Search Tree)

    问题 给出一个元素以递增序列排序的单链表,将其转换为一棵高度平衡的二叉搜索树. 初始思路 二叉搜索树高度平衡,意味着左右子树的高度要平衡.根据二叉树左子树节点小于根节点,右子树节点大于根节点的性质:我 ...

  8. [Swift]LeetCode109. 有序链表转换二叉搜索树 | Convert Sorted List to Binary Search Tree

    Given a singly linked list where elements are sorted in ascending order, convert it to a height bala ...

  9. 有序链表转换二叉搜索树(LeetCode)

    将一个按照升序排列的有序数组,转换为一棵高度平衡二叉搜索树. 本题中,一个高度平衡二叉树是指一个二叉树每个节点 的左右两个子树的高度差的绝对值不超过 1. 示例: 给定有序数组: [-10,-3,0, ...

  10. LeetCode 109——有序链表转化二叉搜索树

    1. 题目 2. 解答 2.1. 方法一 在 LeetCode 108--将有序数组转化为二叉搜索树 中,我们已经实现了将有序数组转化为二叉搜索树.因此,这里,我们可以先遍历一遍链表,将节点的数据存入 ...

随机推荐

  1. 源码安装RocketMQ4.x可视化控制台详细教程

    下载源码 https://github.com/apache/rocketmq-externals 进入 roccketmq-console cd roccketmq-console 编译打包 mvn ...

  2. 位运算与MOD快速幂详细知识点

    最近写的一些题目设计到了数论的取模 如下题 链接:https://ac.nowcoder.com/acm/contest/3003/G来源:牛客网 时间限制:C/C++ 1秒,其他语言2秒 空间限制: ...

  3. 让 rtb 不显示 横纵 滚动条的方法

    让 rtb 不显示 横纵 滚动条的方法: a.设置属性: tb.ScrollBars=None; b.设置属性:rtb.WordWarp=False; c. 添加事件代码: rtb.ContentsR ...

  4. MATLAB默认路径修改

    笔者曾尝试在软件界面的"设置路径"或者Parallel中修改默认路径,但多次尝试均失败.后来经人提点,MATLAB默认文件夹路径可以在桌面图标属性中"起始位置" ...

  5. Java--接口和抽象类有什么区别

    他们都不能实例化对象,都可以包含抽象方法,而且抽象方法必须被继承的类全部实现. 区别: 1.抽象类和接口都不能直接实例化,如果要实例化,抽象类变量必须指向实现所有抽象方法的子类对象,接口变量必须指向实 ...

  6. Linux挂载SMB共享文件夹

    mount -t cifs -o username=xxxx,password=xxxx //PATH/TO/Shared/Folder /mount/point

  7. tableau连接mysql

    1.下载驱动地址:https://dev.mysql.com/downloads/connector/odbc/ 2.选择MSI Installer自动安装自动配置 3.本地127.0.0.1(其他I ...

  8. 【LuckyFrame研究】下载安装包

    下载安装包,可以快速部署 百度网盘链接: https://pan.baidu.com/s/1SNUhzoKFgH2TRQN2Rx711A   提取码: u845 服务端压缩包 V3.X版本:Lucky ...

  9. 第八次团队作业:Beta冲刺(凡事预则立)

    这个作业属于哪个课程 2018级计算机和综合实验班 这个作业要求在哪里 Beta冲刺要求 这个作业的目标 Beta冲刺 改进完善的功能 完善之前年度报告功能 尽快上线小程序 增加的新功能 小程序打卡功 ...

  10. 狂神说SpringBoot笔记之编写一个http接口

    编写一个http接口 1.1.在主程序的同级目录下,新建一个controller包,一定要在同级目录下,否则识别不到 2.代码 1 package com.example.app01.demo.api ...