Leetcode 分隔链表

该博客介绍了如何使用Java实现将链表中的节点根据值是否小于给定的x进行分隔。算法首先遍历链表,分别将小于x的节点和大于等于x的节点存入两个列表,然后重新连接这两个列表,保持原始相对位置。最后返回新链表的头节点。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

分隔链表

题目描述:

给你一个链表的头节点 head 和一个特定值 x ,请你对链表进行分隔,使得所有 小于x 的节点都出现在 大于或等于x 的节点之前。
你应当 保留两个分区中每个节点的初始相对位置。
提示:
链表中节点的数目在范围 [0, 200] 内
-100 <= Node.val <= 100
-200 <= x <= 200

题目链接

示例

在这里插入图片描述

输入:head = [1,4,3,2,5,2], x = 3
输出:[1,2,2,4,3,5]
/**
 * 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) {
        if(head == null) return null;
        List<ListNode> small = new ArrayList<>();
        List<ListNode> big = new ArrayList<>();
        for(ListNode node = head ; node != null ; node = node.next){ // 遍历所有节点
            if(node.val < x) small.add(node);
            else big.add(node);
        }
        for(int i = 0 ; i<small.size()-1 ; i++){
            small.get(i).next = small.get(i+1);
        }
        if(small.size() != 0){
            if(big.size() != 0) small.get(small.size()-1).next = big.get(0);
            for(int i = 0 ; i<big.size()-1 ; i++){
                big.get(i).next = big.get(i+1);
            }
            if(big.size() != 0) big.get(big.size()-1).next = null;
            return small.get(0);
        }else{
            return big.get(0);
        }
    }
}

建立两个数组,一个按照顺序存储小于x的节点,一个存储大于等于x的节点。其余按照题意逻辑即可,详细请看代码。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值