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

【数据结构】_链表经典算法OJ:分割链表(力扣—中等)

目录

1. 题目描述及链接

2. 解题思路

2.1 思路1 

2.2 思路2

2.3 思路3(本题采取该解法)

3. 题解程序


1. 题目描述及链接

题目链接:面试题 02.04. 分割链表 - 力扣(LeetCode)

题目描述:

给你一个链表的头节点 head 和一个特定值 x ,请你对链表进行分隔,使得所有 小于 x 的节点都出现在 大于或等于 x 的节点之前。
你不需要 保留 每个分区中各节点的初始相对位置。

2. 解题思路

2.1 思路1 

创建结构体指针变量curNode遍历原链表:

当curNode的val值大于给定的X时,将该结点尾插后释放该结点;

当curNode的val值小于给定的X时,保持该结点不动,再检查下一结点;

2.2 思路2

重新创建一个新链表,并为其设置一个哨兵位。

创建指针变量curNode遍历原链表,当curNode的val值大于给定的X时,进行尾插操作;

当curNode的val值小于给定的X时,进行头插操作。

2.3 思路3(本题采取该解法)

总思路:

创建两个新链表:大链表和小链表。

创建指针变量curNode遍历原链表,当curNode的val值小于给定的X时,尾插到小链表;

当curNode的val值大于给定的X时,尾插到大链表;

具体思路:

(1)为实现大小链表的正确尾插,需要创建对应指针变量指向当前的尾结点,并在插入后更新尾结点。分别命名为greaterTail和lessTail;

(2)同时,新建链表为空时,空指针->next会导致空指针解引用。故而新链表为空需单独讨论,较为麻烦。此处采用设置哨兵位,分别记为greaterHead和greaterTail:

(3)由于创建了头结点(哨兵位),最后需手动释放;

(4)注意由于哨兵位并不存放实际有效的值,故大链表链接到小链表尾部时,实际链接的大链表第一个结点是greaterHead->next;最后返回新链表的第一个结点是lessHead->next;

(5)考虑特殊情况,若原链表为空,则大小链表仅有哨兵位,即greaterHead->next为NULL,lessTail->next也为NULL,直接返回NULL即可。

3. 题解程序

/*** Definition for singly-linked list.* struct ListNode {*     int val;*     struct ListNode *next;* };*/
typedef struct ListNode ListNode;
struct ListNode* partition(struct ListNode* head, int x) {if(head==NULL){return NULL;}// 创建两个带头链表ListNode* lessHead,*lessTail;ListNode* greaterHead,*greaterTail;lessHead=lessTail=(ListNode*)malloc(sizeof(ListNode));greaterHead=greaterTail=(ListNode*)malloc(sizeof(ListNode));// 遍历原链表,将结点分别尾插到大小链表ListNode* curNode=head;while(curNode!=NULL){if(curNode->val < x){// 尾插到小链表中lessTail->next=curNode;lessTail=lessTail->next;}else{// 尾插到大链表中greaterTail->next=curNode;greaterTail=greaterTail->next;}curNode=curNode->next;}greaterTail->next=NULL;// 链接大小链表:小前大后lessTail->next=greaterHead->next;// 存小链表第一个有效结点,并释放头结点ListNode* newHead=lessHead->next;free(lessHead);free(greaterHead);lessHead=lessTail=NULL;return newHead;
}

注意:

1、必须要将大链表的尾指针的next指针置为NULL,否则会成环,报错为超出时间限制

分析如下:

2、greaterTail->next=NULL 语句必须在 lessTail->next=greaterHead->next语句之前

假设跳出while循环后的代码顺序如下:

// 链接大小链表:小前大后
lessTail->next=greaterHead->next;
greaterTail->next=NULL;

提交报错如下:

这个错误表明程序试图访问一个未正确对齐的内存地址,

通常是由于结构体成员未正确初始化或内存分配问题导致的

考虑原链表为[1](单个结点),x=2的情况

由于在while循环中仅执行了if分支并没有执行else分支,

greaterHead仅调用malloc申请了空间,并未为其val及next赋值。

此时直接使用greaterTail->next为lessTail->next赋值,会导致赋值为随机值。

令greaterTail->next=NULL 语句在 lessTail->next=greaterHead->next语句之前,可以保证greaterHead和greaterTail被初始化为NULL。

http://www.lryc.cn/news/527592.html

相关文章:

  • k8s支持自定义field-selector spec.hostNetwork过滤
  • ICSE‘25 LLM Assistance for Memory Safety
  • 《十七》浏览器基础
  • TikTok 推出了一款 IDE,用于快速构建 AI 应用
  • 阅读springboot源码 记录
  • Linux之内存管理前世今生(一)
  • Beautiful Soup 入门指南:从零开始掌握网页解析
  • 网络通信---MCU移植LWIP
  • Go-并行编程新手指南
  • 基于Django的个人博客系统的设计与实现
  • Python爬虫获取custom-1688自定义API操作接口
  • kaggle-ISIC 2024 - 使用 3D-TBP 检测皮肤癌-学习笔记
  • 滤波电路汇总
  • 1.Template Method 模式
  • MySQL分表自动化创建的实现方案(存储过程、事件调度器)
  • 基于回归分析法的光伏发电系统最大功率计算simulink建模与仿真
  • 计算机毕业设计【任务书】怎么写?
  • GRAPHARG——学习
  • 【Rust自学】15.6. RefCell与内部可变性:“摆脱”安全性限制
  • 14.模型,纹理,着色器
  • 【C语言分支与循环结构详解】
  • 新项目上传gitlab
  • qt-QtQuick笔记之常见项目类简要介绍
  • Continuous Batching 连续批处理
  • 海外问卷调查渠道查如何设置:最佳实践+示例
  • 把本地搭建的hexo博客部署到自己的服务器上
  • 初阶数据结构:链表(二)
  • postgresql根据主键ID字段分批删除表数据
  • 10.business english-global market
  • C 语言实现计算一年中指定日期是第几天 题】