力扣面试150 分隔链表 模拟

Problem: 86. 分隔链表

👨‍🏫 参考题解

Code

Java 复制代码
/**
 * Definition for singly-linked list.
 * public class ListNode {
 *     int val;
 *     ListNode next;
 *     ListNode() {}
 *     ListNode(int val) { this.val = val; }
 *     ListNode(int val, ListNode next) { this.val = val; this.next = next; }
 * }
 */

class Solution {
    public ListNode partition(ListNode head, int x) {
        // 创建两个哑节点,用于存储小于x和大于等于x的节点
        ListNode small = new ListNode(0);
        ListNode smallHead = small; // small链表的头指针
        ListNode large = new ListNode(0);
        ListNode largeHead = large; // large链表的头指针

        // 遍历原始链表
        while (head != null) {
            if (head.val < x) {
                // 如果当前节点值小于x,将该节点连接到small链表
                small.next = head;
                small = small.next; // 更新small指针到当前节点
            } else {
                // 如果当前节点值大于等于x,将该节点连接到large链表
                large.next = head;
                large = large.next; // 更新large指针到当前节点
            }
            // 移动到下一个节点
            head = head.next;
        }

        // large链表的最后一个节点需要指向null,以防止形成循环链表
        large.next = null;

        // 将small链表的最后一个节点指向large链表的头节点
        small.next = largeHead.next;

        // 返回small链表的头节点,即分隔后的新链表的头节点
        return smallHead.next;
    }
}
相关推荐
墨染点香12 分钟前
LeetCode 刷题【138. 随机链表的复制】
算法·leetcode·链表
卡卡酷卡BUG26 分钟前
Java 后端面试干货:四大核心模块高频考点深度解析
java·开发语言·面试
沐怡旸4 小时前
【底层机制】LeakCanary深度解析:从对象监控到内存泄漏分析的完整技术体系
android·面试
Moonbit4 小时前
招募进行时 | MoonBit AI : 程序语言 & 大模型
前端·后端·面试
uhakadotcom4 小时前
基于 TOON + Next.js 来大幅节省 token 并运行大模型
前端·面试·github
野生技术架构师6 小时前
牛客网Java 高频面试题总结(2025最新版)
java·开发语言·面试
王中阳Go6 小时前
又整理了一场真实Golang面试复盘!全是高频坑+加分话术,面试遇到直接抄
后端·面试·go
JavaGuide6 小时前
今年小红书后端开出了炸裂的薪资!
后端·面试
Shinom1ya_6 小时前
算法 day 41
数据结构·算法·leetcode
一匹电信狗8 小时前
【C++】红黑树详解(2w字详解)
服务器·c++·算法·leetcode·小程序·stl·visual studio