当前位置:网站首页>LeetCode 0086.分隔链表
LeetCode 0086.分隔链表
2022-06-27 05:53:00 【Tisfy】
【LetMeFly】86.分隔链表
力扣题目链接:https://leetcode.cn/problems/partition-list/
给你一个链表的头节点 head 和一个特定值x ,请你对链表进行分隔,使得所有 小于x 的节点都出现在 大于或等于x 的节点之前。
你应当 保留 两个分区中每个节点的初始相对位置。
示例 1:

输入:head = [1,4,3,2,5,2], x = 3 输出:[1,2,2,4,3,5]
示例 2:
输入:head = [2,1], x = 2 输出:[1,2]
提示:
- 链表中节点的数目在范围
[0, 200]内 -100 <= Node.val <= 100-200 <= x <= 200
方法一:双指针
这一题我们只需要把原始链表依据“是否小于x”的规则分成两个链表,再把两个链表合并即可。
首先定义两个新的头节点,遍历原始链表,把每个节点分别添加到新的对应的链表中。
最后,把“小于x的链表”的最后一个节点的next指向“大于等于x的链表”的第一个节点,把“大于等于x的链表”的最后一个节点的next置空,返回“小于x的链表”的第一个节点即可。
具体实现可详见代码注释。
- 时间复杂度 O ( N ) O(N) O(N),其中 N N N是原始链表的节点个数
- 空间复杂度 O ( 1 ) O(1) O(1),只需要常数个节点(把节点添加到链表尾部只需要修改next指针,并不需要额外的空间)
AC代码
C++
class Solution {
public:
ListNode* partition(ListNode* head, int x) {
ListNode* le = new ListNode, *ge = new ListNode; // 小于x的链表、大于等于x的链表
ListNode* p1 = le, *p2 = ge; // 两个指针
while (head) {
// 遍历原始链表
if (head->val < x) {
p1->next = head; // 添加到“小于x的链表”后面
p1 = p1->next; // 指针后移
}
else {
p2->next = head; // // 添加到“大于等于x的链表”后面
p2 = p2->next;
}
head = head->next;
}
p1->next = ge->next; // “小于x的链表”的最后一个节点指向“大于等于x的链表”的第一个节点(头节点为空,并未存储值,因此指向ge->next)
p2->next = nullptr; // “大于等于x的链表”的最后一个节点的next置空
return le->next; // 返回“小于x的链表”的第一个节点
}
};
同步发文于CSDN,原创不易,转载请附上原文链接哦~
Tisfy:https://letmefly.blog.csdn.net/article/details/125467594
边栏推荐
- C语言练手小项目(巩固加深知识点理解)
- How JQ gets the reciprocal elements
- openresty使用文档
- Gao Xiang slam14 lecture - note 1
- 《汇编语言-王爽》第3章笔记及实验
- Using domain name forwarding mqtt protocol, pit avoidance Guide
- QT using Valgrind to analyze memory leaks
- C language implementation timer
- Double position relay jdp-1440/dc110v
- WebRTC系列-网络传输之7-ICE补充之提名(nomination)与ICE_Model
猜你喜欢

Junda technology - centralized monitoring scheme for multi brand precision air conditioners

Qt使用Valgrind分析内存泄漏
![[FPGA] design and implementation of frequency division and doubling based on FPGA](/img/84/75d473d3d8e670260ba16d06705c2f.png)
[FPGA] design and implementation of frequency division and doubling based on FPGA

Using domain name forwarding mqtt protocol, pit avoidance Guide

leetcode298周赛记录

多线程基础部分Part2

双位置继电器RXMVB2 R251 204 110DC

多线程基础部分Part 1

NLP-D62-nlp比赛D31&刷题D15

Free SSH and telnet client putty
随机推荐
项目-h5列表跳转详情,实现后退不刷新,修改数据则刷新的功能(记录滚动条)
双位置继电器RXMD2-1MRK001984 DC220V
【Cocos Creator 3.5.1】input.on的使用
C# netcore中 配置帮助类IConfiguration
【养成系】常用正则表达式
Leetcode298 weekly race record
导航【机器学习】
WebRTC系列-網絡傳輸之7-ICE補充之提名(nomination)與ICE_Model
js实现双向数据绑定
Two position relay hjws-9440
函数式 连续式
DAST 黑盒漏洞扫描器 第六篇:运营篇(终)
IAR Systems全面支持芯驰科技9系列芯片
资深【软件测试工程师】学习线路和必备知识点
【QT小点】实现看门狗功能,检测外部程序是否在运行
Wechat applet websocket use case
Avoid asteroids
【Cocos Creator 3.5.1】event.getButton()的使用
Assembly language - Wang Shuang Chapter 3 notes and experiments
《汇编语言-王爽》第3章笔记及实验