当前位置: 首页 > news >正文

牛客网:链表分割

一、题目

函数原型:

ListNode* partition(ListNode* pHead, int x)

二、思路

根据题意,可以设置两个新的链表,将原链表中所有小于x的结点链接到链表1中,大于x的结点链接到链表2中,最后再将两个链表合并即可。

此题有两种写法,一种是带哨兵位的链表,另一种是不带哨兵位的链表。

 实际操作过程中,发现对于两个链表的合并,带哨兵位链表比不带哨兵位链表的代码更加简洁。

(带哨兵位的结点进行尾插时不需要考虑头结点是否为空,且链表合并时可以直接合并,无需考虑某一链表是否为空的情况)

三、代码

代码实现1(带哨兵位)

/*
struct ListNode {int val;struct ListNode *next;ListNode(int x) : val(x), next(NULL) {}
};*/
class Partition {
public:ListNode* partition(ListNode* pHead, int x) {// write code hereListNode *Bnewhead=(ListNode*)malloc(sizeof(ListNode));//小链表的哨兵位ListNode *Btail=Bnewhead;//大链表尾指针ListNode *Snewhead=(ListNode*)malloc(sizeof(ListNode));//大链表的哨兵位ListNode *Stail=Snewhead;//小链表尾指针ListNode *cur=pHead;//遍历指针while(cur){if(cur->val<x)//结点值小于x,尾插到小链表{Stail->next=cur;Stail=cur;}else//结点大于x,尾插到大链表{Btail->next=cur;Btail=cur;}cur=cur->next;}Stail->next=NULL;//小链表尾结点指针域指向空Btail->next=NULL;//大链表尾结点指针域指向空Stail->next=Bnewhead->next;//将大小链表合并return Snewhead->next;//返回新链表的头结点(非哨兵位)}
};

代码实现2(不带哨兵位)

/*
struct ListNode {int val;struct ListNode *next;ListNode(int x) : val(x), next(NULL) {}
};*/
class Partition {
public:ListNode* partition(ListNode* pHead, int x) {// write code hereListNode *cur=pHead;ListNode *Bnewhead=NULL;//大链表头结点ListNode *Btail=NULL;//大链表尾指针ListNode *Snewhead=NULL;//小链表头结点ListNode *Stail=NULL;//小链表尾指针while(cur)//遍历原链表{if(cur->val<x)//结点值小于x,尾插到小链表{if(Stail==NULL)//先判断小链表是否为空,为空则将插入结点作为头结点{Snewhead=Stail=cur;}else//小链表不为空,进行尾插{Stail->next=cur;Stail=cur;}}else{if(Btail==NULL)//先判断大链表是否为空,为空则将插入结点作为头结点{Bnewhead=Btail=cur;}else//大链表不为空,进行尾插{Btail->next=cur;Btail=cur;}}cur=cur->next;}if(Btail)//将大链表尾结点指针域指向空Btail->next=NULL;if(Stail)//将小链表尾结点指针域指向空Stail->next=NULL;//开始合并大小链表if(Stail==NULL)//如果小链表为空,则直接返回大链表{return Bnewhead;}else if(Btail==NULL)//如果大链表为空,则直接返回小链表{return Snewhead;}else if(Stail==NULL&&Btail==NULL)//如果大小链表都为空,则直接返回空{return NULL;}else//大小链表都不为空,将两个链表合并{Stail->next=Bnewhead;return Snewhead;} }
};
http://www.lryc.cn/news/223346.html

相关文章:

  • pytorch(小土堆)深度学习
  • 统计 boy girl 复制出来多少次。 浴谷 P1321题
  • odoo16前端框架分析1 boot.js
  • 酷开科技持续推动智能投影行业创新发展
  • TIA博途中已经被调用的变量,为什么交叉引用时却没有显示调用信息?
  • OSPF下的MGRE实验
  • 论文速览 | TRS 2023: 使用合成微多普勒频谱进行城市鸟类和无人机分类
  • 《网络协议》02. 物理层 · 数据链路层 · 网络层
  • 【chatgpt问答记录】双端队列、栈和函数调用栈
  • 另辟蹊径者 PoseiSwap:背靠潜力叙事,构建 DeFi 理想国
  • 如何查看笔记本电脑电池损耗
  • 一键批量视频剪辑、合并,省时省力,制作专业视频
  • 使用R语言构建HTTP爬虫:IP管理与策略
  • Stable Diffusion源码调试(二)
  • 网络安全(黑客)-零基础自学
  • 在线CRM系统的安全性高吗?企业该如何选择?
  • R-install_miniconda()卸载 | conda命令行报错及解决方法
  • leaflet:利用Leaflet-Geoman绘制多种图形,导出为geojson文件(135)
  • 【C语言基础】第02章_变量与进制
  • 【案例教程】基于AERMOD模型在大气环境影响评价中的实践技术应用
  • 【C语言从入门到放弃 4】字符串,结构体,共用体,位域,typedef详解
  • Linux学习第34天:Linux LCD 驱动实验(一):星星之火可以燎原
  • Flink SQL Window TopN 详解
  • leetcode做题笔记216. 组合总和 III
  • Redis系列-Redis数据类型【3】
  • 机器学习 - 决策树:技术全解与案例实战
  • Opus 1.4 编译脚本
  • 二进制搭建及高可用 Kubernetes v1.20
  • SpringBoot 使用WebSocket打造在线聊天室
  • vcpkg安装第三方库,报错fatal error RC1107: invalid usage; use RC /? for Help