当前位置:首页 > 技术 > 正文内容

链表操作进阶:节点交换、删除与相交检测

访客 技术 2026年6月11日 1

两两交换链表中的节点

为了简化操作,我们可以通过引入一个虚拟头节点来处理。以下是两种实现方法:

迭代法

通过使用临时变量保存相关节点的引用,逐步完成节点交换。


public ListNode swapPairs(ListNode head) {
    ListNode dummy = new ListNode(0);
    dummy.next = head;
    ListNode prev = dummy;

    while (prev.next != null && prev.next.next != null) {
        ListNode first = prev.next;
        ListNode second = prev.next.next;

        // 交换逻辑
        first.next = second.next;
        second.next = first;
        prev.next = second;

        // 移动指针
        prev = first;
    }
    return dummy.next;
}

递归法

利用递归从链表末尾开始逐层返回并进行节点交换。


public ListNode swapPairs(ListNode head) {
    if (head == null || head.next == null) return head;

    ListNode nextNode = head.next;
    head.next = swapPairs(nextNode.next);
    nextNode.next = head;

    return nextNode;
}

删除链表倒数第N个节点

双指针技巧是解决该问题的关键。定义两个指针,让快指针先移动N步,然后同时移动快慢指针直到快指针到达末尾。


public ListNode removeNthFromEnd(ListNode head, int n) {
    ListNode dummy = new ListNode(0);
    dummy.next = head;

    ListNode fast = dummy, slow = dummy;
    for (int i = 0; i < n + 1; i++) {
        fast = fast.next;
    }

    while (fast != null) {
        fast = fast.next;
        slow = slow.next;
    }

    slow.next = slow.next.next;
    return dummy.next;
}

链表相交检测

判断两条链表是否相交,并找到相交点。

方法一:长度对齐法

计算两条链表的长度差,让较长的链表先走几步,之后同步遍历寻找相交点。


public ListNode getIntersectionNode(ListNode headA, ListNode headB) {
    if (headA == null || headB == null) return null;

    int lenA = getLength(headA), lenB = getLength(headB);
    ListNode curA = headA, curB = headB;

    if (lenA > lenB) {
        for (int i = 0; i < lenA - lenB; i++) {
            curA = curA.next;
        }
    } else {
        for (int i = 0; i < lenB - lenA; i++) {
            curB = curB.next;
        }
    }

    while (curA != curB) {
        curA = curA == null ? null : curA.next;
        curB = curB == null ? null : curB.next;
    }
    return curA;
}

private int getLength(ListNode node) {
    int length = 0;
    while (node != null) {
        length++;
        node = node.next;
    }
    return length;
}

方法二:双指针交替遍历法

分别从两条链表头部开始遍历,当一条链表遍历完后切换到另一条链表继续遍历,最终会在相交点相遇。


public ListNode getIntersectionNode(ListNode headA, ListNode headB) {
    ListNode p1 = headA, p2 = headB;

    while (p1 != p2) {
        p1 = p1 == null ? headB : p1.next;
        p2 = p2 == null ? headA : p2.next;
    }
    return p1;
}

环形链表入口检测

首先用快慢指针判断是否存在环,然后通过特定算法找到环的入口。


public ListNode detectCycle(ListNode head) {
    ListNode slow = head, fast = head;
    boolean hasCycle = false;

    while (fast != null && fast.next != null) {
        slow = slow.next;
        fast = fast.next.next;

        if (slow == fast) {
            hasCycle = true;
            break;
        }
    }

    if (!hasCycle) return null;

    ListNode ptr1 = head, ptr2 = slow;
    while (ptr1 != ptr2) {
        ptr1 = ptr1.next;
        ptr2 = ptr2.next;
    }
    return ptr1;
}
标签: 链表

相关文章

Linux crontab 详解

1) crontab 是什么cron 是 Linux 的定时任务守护进程;crontab 是用来编辑/查看“按时间周期执行命令”的表(cron table)。常见两类:用户 crontab:每个用户一份(crontab -e 编辑)系统级 crontab / cron.d:可指定执行用户(/etc/crontab、/etc/cron.d/*)2) crontab 时间...

富文本里可以允许的 HTML 属性

一、所有标签默认允许的安全属性(极少)class        (可选)id           (通常建议禁用)title️ 注意:id 容易被滥用做锚点注入,很多系统直接禁用class 允许的话最好只允许固定前缀(如 editor-*)二、a 标签允许属性<a href="" t...

Mac 安装 Node.js 指南

方法一:通过官网安装包(最简单,适合初学者)如果你只是想快速安装并开始使用,这是最直接的方法。访问 Node.js 官网。页面会显示两个版本:LTS (Recommended For Most Users):长期支持版,最稳定。建议选这个。Current:最新特性版,包含最新功能但可能不够稳定。下载 .pkg 安装包并运行。按照安装向导点击“下一步”即可完成。方法二:使用 Homebrew 安装(...

Dom\HTML_NO_DEFAULT_NS 的副作用:自动加闭合标签

在使用Dom\HTMLDocument时,Dom\HTML_NO_DEFAULT_NS 将禁止在解析过程中设置元素的命名空间, 此设置是为了与DOMDocument向后兼容而存在的。当使用它时,已知的一个副作用就是:自动加闭合标签例如 </img> 为什么会这样?当你使用:Dom\HTML_NO_DEFAULT_NS文档会变成 无命名空间模式,此时内部更接近 XML...

Laravel 事件和监听器创建

在 Laravel 中,使用 Artisan 命令创建 Events(事件) 和 Listeners(监听器) 是非常高效的。你可以通过以下几种方式来实现:1. 手动创建单个 Event如果你只想创建一个事件类,可以使用 make:event 命令:Bashphp artisan make:event UserRegistered执行后,文件将生成在 app/Even...

自定义域名解析神器 dnsmasq

什么是 dnsmasq?dnsmasq 是一个轻量级、功能强大的网络服务工具,专为小型和中等规模网络设计。它是一个综合的网络基础设施解决方案[1]。dnsmasq 能做什么?功能说明应用场景DNS 转发与缓存将 DNS 查询转发到上游服务器(ISP、Google DNS 等),并在本地缓存结果加快 DNS 查询速度,减少外部 DNS 流量本地 DNS解析本地网络设备的主机名,无需编辑&n...

发表评论

访客

◎欢迎参与讨论,请在这里发表您的看法和观点。