【leetcode】链表分割

大家好,我是苏貝,本篇博客带大家刷题,如果你觉得我写的还不错的话,可以给我一个赞👍吗,感谢❤️
在这里插入图片描述


目录

  • 方法1. 不用哨兵位
  • 方法2. 用哨兵位

点击查看题目

在这里插入图片描述

思路:

将链表分为2个链表list1和list2,list1是小于x的所有节点,list2是剩余的节点。最后将list1的最后一个节点指向list2的第一个节点

1

方法1. 不用哨兵位

#include <csignal>
class Partition {public:ListNode* partition(ListNode* pHead, int x) {ListNode* list1 = nullptr;ListNode* i1 = nullptr;ListNode* list2 = nullptr;ListNode* i2 = nullptr;ListNode* cur = pHead;while (cur) {if (cur->val < x) {if (i1 == nullptr) {i1 = list1 = cur;} else {i1->next = cur;i1 = i1->next;}} else {if (i2 == nullptr) {i2 = list2 = cur;} else {i2->next = cur;i2 = i2->next;}}cur = cur->next;}if(list1==nullptr&&list2==nullptr)return nullptr;if(list1==nullptr&&list2!=nullptr)return list2;i1->next=list2;if(list2==nullptr)return list1;i2->next=nullptr;return list1;}
};

2

方法2. 用哨兵位

这种方法就不需要分多钟情况进行讨论,记得最后将开辟的空间释放掉,这是一个好习惯

#include <csignal>
class Partition {public:ListNode* partition(ListNode* pHead, int x) {ListNode* list1,*i1,*list2,*i2,*cur;cur=pHead;list1=i1=(ListNode*)malloc(sizeof(ListNode));list2=i2=(ListNode*)malloc(sizeof(ListNode));while(cur){if(cur->val<x){i1->next=cur;i1=i1->next;}else{i2->next=cur;i2=i2->next;}cur=cur->next;}i1->next=list2->next;i2->next=nullptr;pHead=list1->next;free(list1);free(list2);return pHead;}
};

好了,那么本篇博客就到此结束了,如果你觉得本篇博客对你有些帮助,可以给个大大的赞👍吗,感谢看到这里,我们下篇博客见❤️

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

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

相关文章

忙碌生活下的技术适应力:应对新应用学习带来的困扰与挑战

在当今信息时代&#xff0c;各类应用程序&#xff08;APP&#xff09;渗透到我们生活的方方面面&#xff0c;无论是工作效率提升&#xff0c;还是日常生活便利&#xff0c;都离不开它们的支持。然而&#xff0c;对于在快节奏工作中疲于奔命的现代人来说&#xff0c;当因为生活所…

GO语言学习笔记(与Java的比较学习)(七)

结构与方法 结构体定义 结构体定义的一般方式如下&#xff1a; type identifier struct {field1 type1field2 type2... } type T struct {a, b int} 也是合法的语法&#xff0c;它更适用于简单的结构体。 结构体里的字段都有 名字&#xff0c;像 field1、field2 等&#…

linux服务器连接数

一、要查看 Linux 服务器的最大连接数 我们需要关注两个值&#xff1a;文件描述符限制&#xff08;file descriptor limit&#xff09;和内核参数 "net.core.somaxconn"。 1. 查看文件描述符限制&#xff08;file descriptor limit&#xff09; 文件描述符限制决定了…

System Verilog学习笔记(十)——任务和函数

System Verilog学习笔记&#xff08;十&#xff09;——任务和函数 函数&#xff08;function&#xff09;和任务&#xff08;task&#xff09;可以提高代码的复用性和整洁度。他们的目的在于将大型的过程块切分为更小的片段&#xff0c;而便于阅读和代码维护。 区别 functi…

物联网边缘计算云边协同

文章目录 一、物联网云边协同1.IoT云边协同设计2.物联网平台设计3.物联网平台实现 二、部署环境1.节点配置2.版本信息 三、IoT云边协同部署1.部署Kubernetes集群2.部署KubeEdge3.部署ThingsBoard集群4.部署Node-RED边缘网关4.1.边缘网关功能4.2.部署EMQX4.2.部署Node-RED 5.配置…

(正规api接口代发布权限)短视频账号矩阵系统实现开发--技术全自动化saas营销链路生态

短视频账号矩阵系统实现开发--技术全自动化saas营销链路生态源头开发&#xff08;本篇禁止抄袭复刻&#xff09; 一、短视频矩阵系统开发者架构 云罗短视频矩阵系统saas化系统&#xff0c;开发层将在CAP原则基础上使用分布式架构,对此网站的整体架构采用了基于B/S三层架构模式…

React 模态框的设计(五)主体设计

弹窗的主体设计没什么特别&#xff0c;就是把细分化后的各个功能封装在一个个的小组件内&#xff0c;然后再整合。这样逻辑就分开了&#xff0c;不乱。 弹窗容器 这个容器是弹窗主体的根组件(不含遮罩)&#xff0c;要能根据主题的变化能做出相应的改变。还要记录渲染后的主体…

java016学习记录

Java Web 使用 Java 开发语言完成 Web 后端的项目开发 基于 Web 的应用&#xff1a;网站、APP、小程序 Java 不是做前端的&#xff0c;做后端 Tomcat、Servlet Tomcat 的作用让 Java Web 程序可以正常运行&#xff0c;被浏览器访问 浏览器默认不能访问电脑上的资源&#…

Django Web架构:全面掌握Django模型字段(下)

Django Web架构 全面掌握Django模型字段&#xff08;下&#xff09; - 文章信息 - Author: 李俊才 (jcLee95) Visit me at CSDN: https://jclee95.blog.csdn.netMy WebSite&#xff1a;http://thispage.tech/Email: 291148484163.com. Shenzhen ChinaAddress of this article…

C++之vector

1、vector概念 功能&#xff1a;vector的功能和数组非常相似&#xff0c;可以看成是一个升级版的数组。 vector和普通数组的区别&#xff1a; &#xff08;1&#xff09;数组是静态的&#xff0c;长度不可改变&#xff0c;而vector可以动态扩展&#xff0c;增加长度。…

协议和序列化反序列化

“协议”和序列化反序列化 “协议”的概念&#xff1a; “协议”本身是一种约定俗成的东西&#xff0c;由通讯双方必须共同遵从的一组约定&#xff0c;因此我们一定要将这种约定用计算机语言表达出来&#xff0c;此时双方计算机才能识别约定的相关内容 我们把这个规矩叫做“…

机器学习|决策树

左图的点是一种线性不可分的情况&#xff0c;无法拿一条直线去将进行分开。 每一个节点都代表一个决策&#xff0c;从而导致节点的分流。 最终的目标肯定是要达到分类。 但取得目标的过程是有所谓的好坏。 而这个好坏用熵/信息增益来衡量。 熵是一种用于反映系统混乱程度的物理…

思科网络设备监控

思科是 IT 行业的先驱之一&#xff0c;提供从交换机到刀片服务器的各种设备&#xff0c;以满足中小企业和企业的各种 IT 管理需求。管理充满思科的 IT 车间涉及许多管理挑战&#xff0c;例如监控可用性和性能、管理配置更改、存档防火墙日志、排除带宽问题等等&#xff0c;这需…

Makefile从入门到项目编译实战(学习笔记)

1.make和makefile介绍 1. make make 是一个应用程序&#xff0c;位于 /usr/bin/make 目录下&#xff0c;make 有如下的功能&#xff1a; &#xff08;1&#xff09;解析源程序之间的依赖关系 &#xff08;2&#xff09;根据依赖关系自动维护编译工作 &#xff08;3&#xff09…

Jmeter插件PerfMon Metrics Collector安装使用及报错解决

Jmeter作为一个轻量级的性能测试工具&#xff0c;开源、小巧、灵活的特性使其越来越受到测试人员喜爱。在实际的项目中&#xff0c;特别是跨地区项目&#xff0c;排除合作方指定要求使用Loadrunner作为性能测试工具外&#xff0c;Jmeter会是首选。 本篇文章&#xff0c;就着重…

Python 全栈系列226 GlobalBuffer

说明 为了简化开发程序&#xff0c;特别是需要依赖全局数据的程序&#xff0c;例如&#xff1a;分布式任务需要知道当前可处理的任务&#xff1b;定时程序需要依据某个约束性全局变量。一个附带的好处是会大量减少对数据库产生的请求。 GlobalBuffer的代价并不高&#xff1a;…

基于C++的http通信记录,使用httplib,Windows环境,vscode,mingw

使用了 httplib库&#xff0c;链接&#xff0c;使用该库只需要包含头文件即可&#xff0c;另外在Windows环境下&#xff0c;使用mingw构建项目&#xff0c;需要在编译时链接网络编程库&#xff0c;task.json如下&#xff1a; {"version": "2.0.0","t…

【MATLAB源码-第149期】基于MATLAB的2ASK,2FSK,2PSK,2DPSK等相干解调仿真,输出各节点波形。

操作环境&#xff1a; MATLAB 2022a 1、算法描述 2ASK&#xff08;二进制幅移键控&#xff09;、2FSK&#xff08;二进制频移键控&#xff09;、2PSK&#xff08;二进制相移键控&#xff09;和2DPSK&#xff08;二进制差分相移键控&#xff09;是数字调制技术中的基本调制方…

汽车三元催化器的废品项目详解,三元催化再生项目的回收技术教学

一、教程描述 这是一个收废品项目&#xff0c;就收那些别人不懂的&#xff0c;三元催化器的附加值高&#xff0c;只要掌握技术&#xff0c;怎么玩都行的&#xff0c;只是要放得下你的面子。三元催化器&#xff0c;是安装在汽车排气系统中最重要的机外净化装置&#xff0c;它可…

MATLAB环境基于全局和局部多特征融合的红外图像分割主动轮廓模型

红外图像是一种热图像&#xff0c;不受光照影响&#xff0c;在光照条件差、有烟雾遮挡的环境中&#xff0c;可以辅助或代替可见光成像在各个领域中应用&#xff0c;同时作为热成像&#xff0c;对景物的热辐射敏感&#xff0c;在安全监测、质量检验等领域具有优势。在以下几个方…