链表:常见面试题-根据大小划分区域

news2025/1/10 3:25:23

将单向链表按某值划分为左边小、中间相等、右边大的形式

1)将链表放入数组里,在数组上做partition(类似快排),这是笔试时推荐的写法

2)分为小、中、大三部分,再把各个部分之间串起来,这个是面试推荐使用的。

我们这里重点介绍第二种方法

sH:小于value部分的头 

sT:小于value部分的尾

eH:等于value部分的头

eT: 等于value部分的尾 

bH:大于value部分的头

bT:大于value部分的尾,这个如果不需要保证稳定性的时候可以不要。

代码实现:

package dataStructure.linkedList.practice;

import dataStructure.linkedList.Node;

public class SplitByValue {
    /**
     * 根据value把原来的链表改变为左边小于value、中间相等value、右边大于value的形式
     * @param head  原链表的头节点
     * @param value 设定的划分值
     * @return 返回新链表的头结点
     */
    public static Node<Integer> split(Node<Integer> head, int value) {
        /**
         * sH:小于value部分的头 
         *
         * sT:小于value部分的尾
         *
         * eH:等于value部分的头
         *
         * eT: 等于value部分的尾 
         *
         * bH:大于value部分的头
         *
         * bT:大于value部分的尾,这个如果不需要保证稳定性的时候可以不要。
         */
        Node sH = null;
        Node sT = null;
        Node eH = null;
        Node eT = null;
        Node bH = null;
        Node bT = null;
        while(head != null) {
            Node next = head.next;
            if(head.value < value) {
                if(sT == null) {
                    sH = head;
                    sT = head;
                } else {
                    sT.next = head;
                    sT = head;
                }
            } else if(head.value == value) {
                if(eT == null) {
                    eH = head;
                    eT = head;
                } else {
                    eT.next = head;
                    eT = head;
                }
            } else {
                if(bT == null) {
                    bH = head;
                    bT = head;
                } else {
                    bT.next = head;
                    bT = next;
                }
            }
            head.next = null;
            head = next;
        }

        //每个元素都划分完毕区间之后,现在开始连接各个区间
        //如果sT不为null,说明小于区间有值
        if(sT != null) {
            sT.next = eH;
            //不管什么时候都用eT来连接bH,但是等于区间可能没有值,
            // 这个时候我们把小于区间的尾赋值给等于区间的尾
            eT = eT == null? sT : eT;
        }
        //eT不为null有两种情况:1.等于区间有值,eT就是等于区间的尾 2.等于区间无值,eT就是小于区间的尾
        //两种情况我们都使用eT.next = bH来连接大于区间,这里无需考虑bH是否为空
        if(eT != null) {
            eT.next = bH;
        }
        //如果小于区间的头不为空,返回小于区间的头
        //如果小于区间头为空且等于区间的头不为空,返回等于区间的头
        //其他情况返回大于区间的头
        return sH != null? sH : eH != null? eH: bH;
    }

    public static void main(String[] args) {
        Node n1 = new Node(3);
        Node n2 = new Node(5);
        Node n3 = new Node(2);
        Node n4 = new Node(4);
        Node n5 = new Node(3);
        Node n6 = new Node(3);
        n1.next = n2;
        n2.next = n3;
        n3.next = n4;
        n4.next = n5;
        n5.next = n6;
        Node newHead = split(n1,3);
        while(newHead != null) {
            if(newHead.next != null) {
                System.out.print(newHead.value + "->");
            } else {
                System.out.print(newHead.value);
            }
            newHead = newHead.next;
        }
    }
}

运行结果:

2->3->3->3->5->4
Process finished with exit code 0

欢迎批评指正

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/478416.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

1. 异常概述

目录 1.1 什么是生活的异常 1.2 什么是程序的异常 1.3 异常的抛出机制 1.4 如何对待异常 1.1 什么是生活的异常 男主角小明每天开车上班&#xff0c;正常车程 1 小时。但是&#xff0c;不出意外的话&#xff0c;可能会出现意外。 出现意外&#xff0c;即为异常情况。我们会…

自动化测试和selenium的使用

目录 自动化测试定义 为什么选择selenium来作为我们web自动化测试的工具&#xff1f; 自动化测试定位元素 使用cssSelector定位 使用XPath 定位 操作测试对象 模拟手动从键盘输入 点击对象 获取页面文本 清除对象输入的文本内容 添加等待&#xff08;三种方式&#…

00 SQL介绍

什么是SQL Structured Query Language&#xff1a;结构化查询语言 其实就是定义了操作所有关系型数据库的规则。每一种数据库操作的方式可能会存在一些不一样的地方&#xff0c;我们称为“方言”。 SQL通用语法 SQL 语句可以单行或多行书写&#xff0c;以分号结尾。 可使用空…

干货 | 如何让Zotero更加强大?这六个插件是您的不二之选!

Hello,大家好&#xff01; 这里是壹脑云科研圈&#xff0c;我是喵君姐姐~ Zotero是由安德鲁w梅隆基金会斯隆基金会以及美国博物馆和图书馆服务协会资助开发&#xff0c;是一个免费易用的文献管理软件&#xff0c;可协助我们收集、管理及引用研究资源&#xff0c;包括期刊、书籍…

系统集成项目管理工程师 笔记(第20章:知识产权管理、第21章:法律法规和标准规范)

文章目录 20.1.2 知识产权的特性 58420.2.1 著作权及邻接权 58520.2.2 专利权 58920.2.3 商标权 59221.3 诉讼时效 59921.6.3 标准分级与标准类型 60321.7.2 信息系统集成项目管理常用的技术标准 6061、基础标准2、开发标准3、文档标准4、管理标准 第20章 知识产权管理 584 20.…

LeetCode刷题系列之----->(指针玩转链表篇)(三)

&#x1f349;博客主页&#xff1a;阿博历练记 &#x1f4d6;文章专栏&#xff1a;数据结构与算法 &#x1f50d;代码仓库&#xff1a;阿博编程日记 &#x1f339;欢迎关注&#xff1a;欢迎友友们点赞收藏关注哦 文章目录 &#x1f58b;1.题目描述&#x1f4a1; 逻辑分析&#…

Java+Selenium常用方法梳理

五一假期&#xff0c;祝大家节日快乐。本篇继续自动化测试知识梳理。selenium 自己封装好用的方法&#xff0c;如悬停&#xff0c;句柄获取&#xff0c;可直接调用&#xff0c;实现自己的需求。 1、多窗口切换 即获取页面的句柄&#xff0c;来实现页面的切换&#xff0c;以ha…

GC日志分析工具一GCview使用介绍

目录 一、GCViewer介绍 二、GCViewer 使用 2.1 编译 2.2 使用 一、GCViewer介绍 业界较为流行分析GC日志的两个工具——GCViewer、GCEasy。GCEasy部分功能还是要收费的&#xff0c;今天笔者给大家介绍一下GCViewer的使用与功能点。Memory Analyzer Mat JVM 分析 二、GCVi…

Msfconsole使用永恒之蓝入侵Win7并上传执行可执行文件

提示&#xff1a;文章写完后&#xff0c;目录可以自动生成&#xff0c;如何生成可参考右边的帮助文档 文章目录 前言一、信息收集二、开始入侵1.启动msfconsole2.搜索漏洞3.文件上传其他 总结 前言 提示&#xff1a;这里可以添加本文要记录的大概内容&#xff1a; 我昨天我测…

初识springframework

目录 一.框架的概念&#xff1a; 1.什么是框架&#xff1f; 2.框架的作用&#xff1f; 二.springframework-core(bean容器) 1.什么是bean容器&#xff1f; 对bean容器的理解&#xff08;M&#xff09; 对IOC和DI的理解&#xff08;M&#xff09; DI的底层实现原理是依赖…

Linux:网络套接字

理解源IP地址和目的IP地址 在IP数据包头部中, 有两个IP地址, 分别叫做源IP地址, 和目的IP地址. 思考: 我们光有IP地址就可以完成通信了嘛? 想象一下发qq消息的例子, 有了IP地址能够把消息发送到对方的机器上, 但是还需要有一个其他的标识来区分出, 这个数据要给哪个程序进行…

@Autowired和@Resource注解之间的关系区别,Bean的作用域和生命周期,Spring的执行流程

目录 一. Autowired 和 Resource 注解 二. Bean的作用域 1. singleton(单例模式) 2. prototype(原型模式)(多例模式) 3. 请求作用域&#xff1a;request 4. 会话作用域&#xff1a;session 三. Spring 的执行流程 四. Bean 的生命周期 1. 实例化 2. 设置属性 3. Bea…

【数据结构初阶】环形链表

目录 一、判断链表中是否存在环思路分析 二、求环的长度三、求入环点 一、判断链表中是否存在环 题目链接&#xff1a; 判断链表中是否存在环 思路 把它转换为追击问题&#xff08;快慢指针&#xff09; 快指针比慢指针多走一步&#xff0c;当快指针正好进入环时&#xff0c;慢…

脑科学数据挖掘论文精读系列(1)【抑郁对大脑神经影响和对脊椎损伤患者运动恢复的影响探究】

Depression mediated the relationships between precentral-subcortical causal links and motor recovery in spinal cord injury patients 手动防爬虫&#xff0c;原创作者CSDN&#xff1a;总是重复名字我很烦啊&#xff0c;联系邮箱daledeng123163.com直达原文 这是一篇收…

操作系统——操作系统用户界面

0.关注博主有更多知识 操作系统入门知识合集 目录 3.1操作系统启动过程 3.1.1BIOS和主引导记录MBR 思考题&#xff1a; 3.1.2操作系统的启动过程 思考题&#xff1a; 3.2用户界面 3.2.1用户界面概念 思考题&#xff1a; 3.2.2系统调用 3.1操作系统启动过程 3.1.1BIO…

【五一创作】使用Resnet残差网络对图像进行分类(猫十二分类,模型定义、训练、保存、预测)(一)

使用Resnet残差网络对图像进行分类 &#xff08;猫十二分类&#xff0c;模型定义、训练、保存、预测&#xff09;(一&#xff09; 目录 一、项目简介 二、环境说明 1、安装库 2、导入需要的库 三、分类过程 &#xff08;1&#xff09;、解压数据集 &#xff08;2&#xf…

Spring中的Bean

1. Bean的配置 Spring 可以被看作是一个大型工厂&#xff0c;这个工厂的作用就是生产和管理 Spring 容器中的Bean。如果想要在项目中使用这个工厂&#xff0c;就需要开发者对Spring 的配置文件进行配置。 Spring 容器支持XML 和 Properties 两种格式的配置文件&#xff0c;在实…

【Python Web】Flask超实用基础知识总结(内附代码)

Flask是一种轻量级Web应用框架&#xff0c;使用Python编写。它是一个简单易用的框架&#xff0c;适合构建小型到中型的Web应用程序。Flask提供了基本的Web开发功能&#xff0c;如路由、请求处理、模板渲染、文件上传等。 下面是Flask的一些基础语法 文章目录 1.静态文件处理2.…

【建议收藏】计算机视觉是什么?这几个计算机视觉的核心任务你真的了解吗?

文章目录 &#x1f4da;引言&#x1f4d6;计算机视觉的核心任务&#x1f4d1;图像分类和对象识别&#x1f4d1;目标检测&#x1f4d1;语义分割&#x1f4d1;实例分割&#x1f4d1;图像生成 &#x1f4d6;计算机视觉的应用领域&#x1f4d1;人脸识别&#x1f4d1;自动驾驶&#…

【论文阅读】LORA: LOW-RANK ADAPTATION OF LARGE LAN- GUAGE MODELS

3.最近很多工作好像都绕不开lora&#xff0c;无论是sd还是llm.... 1. 背景 问题&#xff1a;大模型重新训练所有模型参数的完全微调变得不太可行。lora在做什么 我们提出了低秩自适应&#xff0c;即LoRA&#xff0c;它冻结预先训练的模型权重&#xff0c;并将可训练的秩分解矩…