前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >【每日一题】牛客网——链表分割

【每日一题】牛客网——链表分割

作者头像
爱敲代码的小杨.
发布2024-05-07 18:37:11
610
发布2024-05-07 18:37:11
举报
文章被收录于专栏:JavaJava

1. 题目描述

现有一链表的头指针 ListNode* pHead,给一定值x,编写一段代码将所有小于x的结点排在其余结点之前,且不能改变原来的数据顺序,返回重新排列后的链表的头指针。

题目链接

2. 思路

  1. 判断链表是否为空,如果为空返回null
  2. 定于指针cur指向头节点,即链表的头节点
  3. 定义指针bsbe,分别指向小于x链表的头节点和尾节点
  4. 定义指针asae,分别指向大于等于x链表的头节点和尾节点
  5. 循环遍历链表,直到遍历完所有的节点
    • 如果当前节点的val值小于x
      1. 判断小于x的链表中是否为空,如果为空则bsbe都指向当前节点
      2. 否则benext指向当前节点,be指向benext
    • 当前节点的val值大于等于x
      1. 判断大于等于x的链表中是否为空,如果为空则asae都指向当前节点
      2. 否则aenext指向当前节点,ae指向aenext
    • cur指向curnext
  6. 如果小于x的链表为空,则返回as
  7. 否则benext指向as
  8. 如果as不为空,则将asnext值为空(原链表的最后一个节点的值小于x
  9. 返回bs

3. 代码

代码语言:javascript
复制
import java.util.*;

/*
public class ListNode {
    int val;
    ListNode next = null;

    ListNode(int val) {
        this.val = val;
    }
}*/
public class Partition {
    public ListNode partition(ListNode pHead, int x) {
        if (pHead == null) {
            return null;
        }
        // write code here
        // 定义cur 指向头结点
        ListNode cur = pHead;

        ListNode bs = null;
        ListNode be = null;
        ListNode as = null;
        ListNode ae = null;

        while (cur != null) {
            if (cur.val < x) {
                if (bs == null) { // 判断是不是第一个元素
                    bs = cur;
                    be = cur;
                } else {
                    be.next = cur;
                    be = be.next;
                }
            } else {
                if (as == null) {
                    as = cur;
                    ae = cur;
                } else {
                    ae.next = cur;
                    ae = ae.next;
                }
            }
            cur = cur.next;
        }
        if (be == null) {
            return as;
        }
        be.next = as;
        if (as != null) {
            ae.next = null;
        }
        return bs;
    }
}

运行结果:

本文参与?腾讯云自媒体分享计划,分享自作者个人站点/博客。
原始发表:2024-05-07,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客?前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与?腾讯云自媒体分享计划? ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 1. 题目描述
  • 2. 思路
  • 3. 代码
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档
http://www.vxiaotou.com