带哨兵位的单链表之 链表分割

简介: 带哨兵位的单链表之 链表分割

认识

链表分为两种:带头结点的不带头结点的

之前我们学习了不带哨兵位的单链表,并实现了相关代码

现在我们认识一下带哨兵位头结点的单链表

plist指向带哨兵位的头结点

这个结点不存储有效数据

如果为空链表:

  • 不带头:plist指向NULL
  • 带头:plist指向head,一定不会指向NULL

优势

带哨兵位的单链表也有他自己的优势,我们用一道题来证明一下:

链表分割_牛客题霸_牛客网 (nowcoder.com)

题目描述:

题目分析

假设有下面这个链表,给定数字5

那么排序后就是这样,不改变原来是数据顺序

可以分割成两个链表,plist1和plist2,小于x的结点尾插到plist1,否则尾插到plist2

当链表的数据全部尾插结束后,将plist2头结点尾插到plist1,这个时候带哨兵位的头结点就非常有优势了

我们可以定义两个头结点head和head2,分别作为两个链表的哨兵位,再定义两个尾结点tail1和tail2方便两个链表的尾插,定义cur遍历链表,和x值做比较

代码示例

我们思路清晰了就可以写代码了:

认识
链表分为两种:带头结点的和不带头结点的
之前我们学习了不带哨兵位的单链表,并实现了相关代码
现在我们认识一下带哨兵位头结点的单链表:
plist指向带哨兵位的头结点
这个结点不存储有效数据
如果为空链表:
不带头:plist指向NULL
带头:plist指向head,一定不会指向NULL 
优势
带哨兵位的单链表也有他自己的优势,我们用一道题来证明一下:
 链表分割_牛客题霸_牛客网 (nowcoder.com)
题目描述:
题目分析 
假设有下面这个链表,给定数字5
那么排序后就是这样,不改变原来是数据顺序
可以分割成两个链表,plist1和plist2,小于x的结点尾插到plist1,否则尾插到plist2
当链表的数据全部尾插结束后,将plist2头结点尾插到plist1,这个时候带哨兵位的头结点就非常有优势了
我们可以定义两个头结点head和head2,分别作为两个链表的哨兵位,再定义两个尾结点tail1和tail2方便两个链表的尾插,定义cur遍历链表,和x值做比较
代码示例
我们思路清晰了就可以写代码了:
/*
struct ListNode {
    int val;
    struct ListNode *next;
    ListNode(int x) : val(x), next(NULL) {}
};*/
#include <cstdlib>
class Partition {
public:
    ListNode* partition(ListNode* pHead, int x) {
        // write code here
        struct ListNode* head1,* head2,* tail1,* tail2;
        head1=(struct ListNode*)malloc(sizeof(struct ListNode));
        head2=(struct ListNode*)malloc(sizeof(struct ListNode));
        tail1=head1;
        tail2=head2;
        struct ListNode* cur=pHead;
        while(cur)
        {
            if(cur->val<x)
            {
                tail1->next=cur;
                tail1=tail1->next;
            }
            else
            {
                tail2->next=cur;
                tail2=tail2->next;
            }
            cur=cur->next;
        }
        tail1->next=head2->next;
        tail2->next=NULL;
        pHead=head1->next;
        free(head1);
        free(head2);
        return pHead;
    }
};
 由于该题只能用c++,但是我们可以完全按照C语言的语法规则写内部,最后就可以通过了;

由于该题只能用c++,但是我们可以完全按照C语言的语法规则写内部,最后就可以通过了;

相关文章
|
1月前
|
存储 缓存 算法
链表全景:探索单链表、双向链表与循环链表【实战演练】
链表全景:探索单链表、双向链表与循环链表【实战演练】
36 3
|
1月前
|
存储
【单链表】数据结构单链表的实现
【单链表】数据结构单链表的实现
|
15天前
|
存储
链表入门(单链表讲)
链表入门(单链表讲)
链表入门(单链表讲)
|
3天前
|
存储
【海贼王的数据航海】链表—单链表
【海贼王的数据航海】链表—单链表
7 0
|
1月前
|
存储 编译器
单链表与双链表实现
单链表与双链表实现
27 4
|
15天前
最复杂的链表(带哨兵位的双向循环链表)
最复杂的链表(带哨兵位的双向循环链表)
|
1月前
|
算法
【数据结构与算法 | 基础篇】模拟LinkedList实现的链表(无哨兵)
【数据结构与算法 | 基础篇】模拟LinkedList实现的链表(无哨兵)
|
1月前
特殊链表(循环单链表,循环双链表,静态链表)
特殊链表(循环单链表,循环双链表,静态链表)
23 3
|
22天前
|
算法
数据结构和算法学习记录——线性表之单链表(下)-头插函数、尾删函数、头删函数、查找函数、pos位置插入&删除数据、单链表销毁
数据结构和算法学习记录——线性表之单链表(下)-头插函数、尾删函数、头删函数、查找函数、pos位置插入&删除数据、单链表销毁
21 0
|
22天前
|
存储 算法
数据结构和算法学习记录——线性表之单链表(上)-初始单链表及其尾插函数(顺序表缺陷、单链表优点、链表打印)
数据结构和算法学习记录——线性表之单链表(上)-初始单链表及其尾插函数(顺序表缺陷、单链表优点、链表打印)
16 0