【链表OJ】链表分割

news2024/11/24 7:26:23

⭐️ 往期相关文章

💫链接1:链表中倒数第k个结点(快慢指针问题)
💫链接2:leetcode 876.链表的中间结点(快慢指针问题)
💫链接3:leetcode 206.反转链表
💫链接4:leetcode 203.移除链表元素
💫链接5:数据结构-手撕单链表+代码详解


⭐️ 题目描述

在这里插入图片描述
🌟 牛客链接:链表分割

1️⃣ 代码:

思路:不采用带哨兵卫的头结点。准备一个记录小于目标的值的头指针尾指针(这里尾指针记录每次尾插过后的新的尾),再准备一个大于等于目标值的头指针尾指针(这里尾指针记录每次尾插过后的新的尾)主要为了方便尾插,不用每次找尾。但是要考虑第一次尾插情况,因为第一次为 NULL 需要特殊处理。最后把记录小数的尾指针和记录大数的头指针链接即可。还有要考虑极端情况,当链表中所有数都大于目标值时,那么直接返回记录大数的头指针。小于同理。还有一种特殊情况是,大数的尾结点里的 next 指针可能指向其他元素,防止这种环的问题产生,所以要把大数的尾指针置为 NULL

/*
struct ListNode {
    int val;
    struct ListNode *next;
    ListNode(int x) : val(x), next(NULL) {}
};*/
class Partition {
public:
    ListNode* partition(ListNode* pHead, int x) {
        // 5 3 7 8 2 1  x = 4
        // 3 2 1 5 7 8
        // 新的头
        struct ListNode* largeHead = NULL;
        struct ListNode* smallHead = NULL;
        // 记录大的数尾插位置
        struct ListNode* largeCur = NULL;
        // 记录小的数尾插位置
        struct ListNode* smallCur = NULL;

        struct ListNode* cur = pHead;
        while (cur != NULL) {
            if (cur->val < x) {
                if (smallCur == NULL) {
                    smallCur = cur;
                    smallHead = smallCur;
                } else {
                    smallCur->next = cur;
                    smallCur = smallCur->next;
                }
            } else {
                if (largeCur == NULL) {
                    largeCur = cur;
                    largeHead = largeCur;
                } else {
                    largeCur->next = cur;
                    largeCur = largeCur->next;
                }
            }
            cur = cur->next;
        }
        // 如果全部数都比目标数大
        if (smallHead == NULL) {
            return largeHead;
        }
        // 如果全部数都比目标数小
        if (largeHead == NULL) {
            return smallHead;
        }


        // 连接
        smallCur->next = largeHead;

        // 尾断开
        largeCur->next = NULL;
        
        return smallHead;
    }
};

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

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

相关文章

[Golang实战] sql建表,不用外键,多个表之间如何建立起联系?

问题描述 下面是我的建表语句&#xff0c;在其中我并没有使用到外键&#xff0c;去关联三个表&#xff0c;但是我发现三个表中具有隐式的关联关系 create database library; use library; DROP TABLE IF EXISTS user;CREATE TABLE user(id bigint(20) NOT NULL AUTO_INCREMEN…

Java基础-多线程JUC-线程池和自定义线程池

1. 线程池 主要核心原理 不推荐Executors创建没有上线的线程池&#xff0c;建议使用自定义的线程池&#xff1b; Java工具类创建线程池&#xff1b; public class demo16 {public static void main(String[] args) {/*** public static ExecutorService newCachedThreadPoo1() …

一款打击感超强的动作游戏《流星蝴蝶剑》

文章目录 玩法介绍1.介绍2.按键操作3.流星蝴蝶剑各种武器招式秘籍 游戏优点游戏缺点游戏停服的原因游戏后续发展常见的的游戏道具1.四种水晶2.四种包子3.多种属性加成道具 《流星蝴蝶剑》的游戏打击感分析1.什么是游戏打击感2.影响游戏打击感的经典要素3.几个体现打击感的镜头动…

国产自研GPT大语言模型|实在智能TARS

目录 前言 TARS名字由来 实在智能 TARS 应用演示 大模型RPA 大模型IDP 最后 前言 Chat-GPT问世以来&#xff0c;国内外知名公司纷纷加入到大模型的研发行列中&#xff0c;2023年无疑成为大模型发展元年。百度、谷歌等科技巨头百家争鸣&#xff0c;新锐科技公司也不甘…

成为自动化测试的7种技能

目录 前言&#xff1a; 1.自动化测试员技能——编程语言 设计框架 2.自动化测试员技能–出色的手动测试技能 人眼就是一切 某些测试只能手动完成 自动化测试可能包含漏洞 某些方案不适用于自动化测试 您对整个问题都有个想法 3.自动化测试员技能–自动化工具专业知识…

【教你做直播产品】线上K歌软件开发技术选型

摘要 在线K歌软件的开发有许多技术难点&#xff0c;需考虑到音频录制和处理、实时音频传输和同步、音频压缩和解压缩、设备兼容性问题等技术难点外&#xff0c;此外&#xff0c;开发者还应关注音乐版权问题&#xff0c;确保开发的应用合规合法。 前言 前面写了几期关于直播 …

中小企业如何应用大数据?_光点科技

随着信息技术的快速发展&#xff0c;大数据已经成为当今商业世界中的热门话题。大数据不仅对大型企业有益&#xff0c;对中小企业同样具有巨大潜力。然而&#xff0c;很多中小企业对于如何应用大数据感到困惑。 首先&#xff0c;中小企业可以利用大数据来优化营销策略。大数据分…

AidLux+无人机——AI电力巡检新模式

近年来&#xff0c;航空、遥感、以及信息处理等技术迅速发展&#xff0c;使得无人机在电力巡检上逐渐应用开来。 无人机电力巡检作为新型电力巡检方式&#xff0c;不受地形地貌限制、便携易用且高效&#xff0c;能够极大程度降低传统巡检工作的风险和失误&#xff0c;提升工作…

<QT开发> QT开发工具-之-QT应用程序打包

&#xff1c;QT开发&#xff1e; QT开发工具-之-QT应用程序打包 一 前言 笔者为什么会写这篇文章呢&#xff1f;这是因为&#xff0c;笔者使用windows QT开发了一个测试工具。目的是通过TCP/IP测试其它应用程序。首先这个QT程序是笔者自己开发的&#xff0c;所以笔者的电脑当…

如何写出一份还OK的英文简历

大家好&#xff0c;其实对于SAP这个全球超过80%都会用的ERP软件&#xff0c;对于我们顾问而言&#xff0c;永远都有成长空间。 当你技术达到一定水平的时候&#xff0c;你会发现受语言限制更多。 比如国内项目做得差不多了&#xff0c;想尝试国外global项目&#xff1b;或是遇…

关于使用Ajax技术无法获取本地数据的问题

今天在学习Ajax技术时&#xff0c;在按照课程学习的过程中&#xff0c;发现在浏览器中无法获取显示本地文件中的数据。在网上搜索一番后发现&#xff0c;是因为直接在默认浏览器中直接打开HTML文件&#xff0c;而不是通过web服务器访问&#xff0c;会出现跨域请求会受到浏览器的…

C-Free 的最佳替代品 初学者的C/C++ IDE利器 小熊猫C++

IDE选择之困 对于一个C/C的初学者来说&#xff0c;一个好用的IDE会让你快速入门、爱上编程&#xff1b;相反&#xff0c;一个难用的IDE则会让人还没入门就放弃。不要跟我说vimmake&#xff0c;初学者哪里懂这个&#xff0c;windows都不一定玩的溜&#xff0c;玩linux会让人更…

《水经注地图服务》发布的影像数据在水经微图中调用

古人云&#xff1a;“工欲善其事&#xff0c;必先利其器。”意思是说&#xff1a;工匠想要使他的工作做好&#xff0c;一定要先让工具锋利&#xff0c;比如要做好一件事&#xff0c;准备工作非常重要。 语出《论语卫灵公》&#xff1a;子贡问为仁。子曰&#xff1a;“工欲善其…

【AJAX】使用JQ发送AJAX发送请求

首先要引入JQ <script crossorigin"anonymous" src"https://cdn.staticfile.org/jquery/1.10.2/jquery.min.js"></script>服务端代码 // 服务端准备 // 1、引入express const express require(express); // 2、创建应用对象 const app expr…

SpringBoot+JWT实现单点登录解决方案

一、什么是单点登录? 单点登录是一种统一认证和授权机制&#xff0c;指在多个应用系统中&#xff0c;用户只需要登录一次就可以访问所有相互信任的系统&#xff0c;不需要重新登录验证。 单点登录一般用于互相授信的系统&#xff0c;实现单一位置登录&#xff0c;其他信任的…

【nav_msgs/Path.h发布路径】

#include <nav_msgs/Path.h> 是一个 ROS (Robot Operating System) 中的包含文件。它是用于包含 nav_msgs/Path 消息类型的头文件,这是一个标准的 ROS 消息类型。 nav_msgs/Path 消息类型常用于机器人导航系统中,以表示路径。这种路径通常由一系列的位置点组成,这些点…

Spirngboot读取html文件到字符串

一、引入依赖 <dependency><groupId>cn.hutool</groupId><artifactId>hutool-all</artifactId><version>5.3.5</version></dependency> 二、直接读取返回 public String getContent(String path){try {File file ResourceUt…

如何限定IP访问服务器端口(只允许指定IP访问数据库服务器的1433端口)

1、找到“控制面板”->“Windows防火墙”->“高级设置”->“入站规则” 2、选中左侧的"入站规则"&#xff0c;并点击右侧的"新建规则" 3、选择"端口"&#xff0c;点击"下一步" 4、输入要限定访问的端口&#xff0c;这里是要…

瑞吉外卖-Day02

title: 瑞吉外卖-Day02 abbrlink: ‘1’ date: 2023-04-1 19:30:00 瑞吉外卖-Day02 课程内容 完善登录功能新增员工员工信息分页查询启用/禁用员工账号编辑员工信息 分析前端页面效果是如何实现的 为什么点击左边 右边会根着变化 [外链图片转存失败,源站可能有防盗链机制…

【js】JS实现根据两点经纬度位置获取距离:

文章目录 一、JS实现根据两点经纬度位置获取距离&#xff1a;二、效果&#xff1a; 一、JS实现根据两点经纬度位置获取距离&#xff1a; // 根据经纬度计算距离&#xff0c;参数分别为第一点的纬度&#xff0c;经度&#xff1b;第二点的纬度&#xff0c;经度 function getDist…