2025年- H118-Lc86. 分隔链表(链表)--Java版

1.题目

2.思路

首先维护两个链表,一个链表存储小于x的数,另一个链表存储大于x的数。然后再用小链表的最后一个数指向大链表的第一个数,大链表的最后一个数指向NULL。

创建两个虚拟头结点分别指向小链表的第1个节点和大链表的最后一个节点。

largehead不变的,暂存了大链表的头结点。smallhead不变的,暂存了小链表的头结点

3.代码实现

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) {

        ListNode small=new ListNode(0);
        ListNode smallHead=small;
        ListNode large=new ListNode(0);
        ListNode largeHead=large;
        //如果头结点不为空
        while(head!=null)
        {
          if(head.val<x)
          {
            //小链表虚拟头结点的下一个数指向小链表的头结点
            small.next=head; //1=1
            small=small.next;//small=
          }else
          {large.next=head;
            //大链表的虚拟头结点的下一个数 指向大链表的头结点
            large=large.next;

          }
          //如果数顺序排序的,head指针后移
          head=head.next;
        }
        //最后重新链接一下大链表和小链表
        //大链表的最后一个节点的下一个数指向空
        large.next=null;

        //小链表的最后一个结点的下一个数指向大链表的第一个数
        //largehead不变的,暂存了大链表的头结点
        small.next=largeHead.next;

        //返回小链表的第一个数,smallhead不变的,暂存了小链表的头结点
        return smallHead.next;
        
    }
}
相关推荐
qq_12498707531 小时前
基于SSM的动物保护系统的设计与实现(源码+论文+部署+安装)
java·数据库·spring boot·毕业设计·ssm·计算机毕业设计
Coder_Boy_1 小时前
基于SpringAI的在线考试系统-考试系统开发流程案例
java·数据库·人工智能·spring boot·后端
Mr_sun.1 小时前
Day06——权限认证-项目集成
java
瑶山1 小时前
Spring Cloud微服务搭建四、集成RocketMQ消息队列
java·spring cloud·微服务·rocketmq·dashboard
abluckyboy1 小时前
Java 实现求 n 的 n^n 次方的最后一位数字
java·python·算法
2301_818732061 小时前
前端调用控制层接口,进不去,报错415,类型不匹配
java·spring boot·spring·tomcat·intellij-idea
2501_941982051 小时前
深度对比:Java、Go、Python 实现企微外部群推送,哪个效率更高?
java·golang·企业微信
马猴烧酒.2 小时前
【面试八股|JAVA多线程】JAVA多线程常考面试题详解
java·服务器·数据库
sino爱学习2 小时前
高性能线程池实践:Dubbo EagerThreadPool 设计与应用
java·后端
不知名XL3 小时前
day50 单调栈
数据结构·算法·leetcode