01.数据结构篇-链表

1.找出两个链表的交点

160. Intersection of Two Linked Lists (Easy)

Leetcode / 力扣

例如以下示例中 A 和 B 两个链表相交于 c1:

A:          a1 → a2
                    ↘
                      c1 → c2 → c3
                    ↗
B:    b1 → b2 → b3

但是不会出现以下相交的情况,因为每个节点只有一个 next 指针,也就只能有一个后继节点,而以下示例中节点 c 有两个后继节点。

A:          a1 → a2       d1 → d2
                    ↘  ↗
                      c
                    ↗  ↘
B:    b1 → b2 → b3        e1 → e2

要求时间复杂度为 O(N),空间复杂度为 O(1)。如果不存在交点则返回 null。

设 A 的长度为 a + c,B 的长度为 b + c,其中 c 为尾部公共部分长度,可知 a + c + b = b + c + a。

当访问 A 链表的指针访问到链表尾部时,令它从链表 B 的头部开始访问链表 B;同样地,当访问 B 链表的指针访问到链表尾部时,令它从链表 A 的头部开始访问链表 A。这样就能控制访问 A 和 B 两个链表的指针能同时访问到交点。

如果不存在交点,那么 a + b = b + a,以下实现代码中pa和pb会同时为 null,从而退出循环。

public class Solution {
    public ListNode getIntersectionNode(ListNode headA, ListNode headB) {
        ListNode pa = headA, pb = headB;
        while(pa != pb){
            pa = (pa == null ? headB : pa.next);
            pb = (pb == null ? headA : pb.next);
        }
        return pa;
    }
}

2.翻转链表

206. Reverse Linked List (Easy)

Leetcode / 力扣

双指针迭代
我们可以申请两个指针,第一个指针叫 pre,最初是指向 null 的。
第二个指针 cur 指向 head,然后不断遍历 cur。
每次迭代到 cur,都将 cur 的 next 指向 pre,然后 pre 和 cur 前进一位。
都迭代完了(cur 变成 null 了),pre 就是最后一个节点了。

class Solution {
    public ListNode reverseList(ListNode head) {
        ListNode pre = null, cur = head;
        
        while(cur != null){
            ListNode tmp = cur.next;
            cur.next = pre;
            pre = cur;
            cur = tmp;
        }
        return pre;

    }
}

相关推荐

  1. 数据结构 循环 双向

    2024-02-14 10:58:01       39 阅读
  2. 02 数据结构

    2024-02-14 10:58:01       22 阅读
  3. 数据结构

    2024-02-14 10:58:01       36 阅读

最近更新

  1. TCP协议是安全的吗?

    2024-02-14 10:58:01       18 阅读
  2. 阿里云服务器执行yum,一直下载docker-ce-stable失败

    2024-02-14 10:58:01       19 阅读
  3. 【Python教程】压缩PDF文件大小

    2024-02-14 10:58:01       19 阅读
  4. 通过文章id递归查询所有评论(xml)

    2024-02-14 10:58:01       20 阅读

热门阅读

  1. Android:自定义控件

    2024-02-14 10:58:01       29 阅读
  2. 算法笔记P67

    2024-02-14 10:58:01       29 阅读
  3. 兵棋推演是离散问题,深度学习是连续问题

    2024-02-14 10:58:01       32 阅读
  4. Gateway中Spring Security6统一处理CORS

    2024-02-14 10:58:01       30 阅读
  5. 第一章 文档数据库 (DocDB) 简介

    2024-02-14 10:58:01       30 阅读
  6. Ajax 入门

    2024-02-14 10:58:01       35 阅读
  7. 796. 子矩阵的和

    2024-02-14 10:58:01       35 阅读
  8. λ-矩阵的多项式展开

    2024-02-14 10:58:01       31 阅读
  9. 数据库第三章作业-SQL语言

    2024-02-14 10:58:01       31 阅读
  10. 局部加权回归

    2024-02-14 10:58:01       31 阅读
  11. Day32 贪心算法part02

    2024-02-14 10:58:01       33 阅读
  12. c++ STL系列——(五)map

    2024-02-14 10:58:01       21 阅读