作者:旧梦拾遗186
专栏:数据结构成长日记
目录
链表的中间结点https://leetcode.cn/problems/middle-of-the-linked-list/
给定一个头结点为 head 的非空单链表,返回链表的中间结点。
如果有两个中间结点,则返回第二个中间结点。
示例 1:
输入:[1,2,3,4,5]
输出:此列表中的结点 3 (序列化形式:[3,4,5])
返回的结点值为 3 。 (测评系统对该结点序列化表述是 [3,4,5])。
注意,我们返回了一个 ListNode 类型的对象 ans,这样:
ans.val = 3, ans.next.val = 4, ans.next.next.val = 5, 以及 ans.next.next.next = NULL.
示例 2:输入:[1,2,3,4,5,6]
输出:此列表中的结点 4 (序列化形式:[4,5,6])
由于该列表有两个中间结点,值分别为 3 和 4,我们返回第二个结点。
提示:
给定链表的结点数介于 1 和 100 之间。
思路:可以遍历一遍求出长度在除以2。不过我们采用另一种做法只遍历链表一遍即可,采用快慢指针即可。慢指针一次走一步,快指针一次走两步,我们要区分是奇数个结点还是偶数个结点。
对于奇数个:fast到尾,而slow刚好到中间结点
对于偶数个:fast走到空,而slow刚好走到中间结点。
struct ListNode* middleNode(struct ListNode* head){ struct ListNode* fast=head; struct ListNode* slow=head; while(fast!=NULL&&fast->next!=NULL) { slow=slow->next; fast=fast->next->next; } return slow; }
描述
输入一个链表,输出该链表中倒数第k个结点。
示例1
输入:
1,{1,2,3,4,5}返回值:
{5}
- struct ListNode* FindKthToTail(struct ListNode* pListHead, int k ) {
- struct ListNode* fast=pListHead;
- struct ListNode* slow=pListHead;
- int i=0;
- for(i=0;i
- {
-
- if(fast==NULL)
- return NULL;
-
- fast=fast->next;
- }
- while(fast)
- {
- fast=fast->next;
- slow=slow->next;
- }
- return slow;
-
- }
- class Solution {
- public:
- ListNode* FindKthToTail(ListNode* pListHead, unsigned int k) {
- struct ListNode* slow = pListHead;
- struct ListNode* fast = slow;
- while(k--)
- {
- if(fast)
- fast = fast->next;
- else
- return NULL;
- }
-
- while(fast)
- {
- slow = slow->next;
- fast = fast->next;
- }
-
- return slow;
- }
- };
链表的分割
描述
现有一链表的头指针 ListNode* pHead,给一定值x,编写一段代码将所有小于x的结点排在其余结点之前,且不能改变原来的数据顺序,返回重新排列后的链表的头指针。
题解
思路:我们给出两个带头结点的新链表,值小于X的放在第一条链表,值大于X的放在第二条链表,最后两个新链表连接起来即可。同时,我们需要注意到如果链表为空的时候,我们可以画个图:
- public:
- ListNode* partition(ListNode* pHead, int x) {
- // write code here
- ListNode*lessguard = (ListNode*)malloc(sizeof(ListNode));
- lessguard->next = NULL;
- ListNode*lesstail = lessguard;
- ListNode*greaterguard = (ListNode*)malloc(sizeof(ListNode));
- greaterguard->next =NULL;
- ListNode*greatertail = greaterguard;
- ListNode*cur = pHead;
- while(cur)
- {
- if(cur->val
- {
- lesstail->next = cur;
- lesstail = lesstail->next;
- }
- else
- {
- greatertail->next = cur;
- greatertail = greatertail->next;
- }
- cur = cur->next;
- }
- lesstail->next = greaterguard->next;
- greatertail->next = NULL;
- pHead = lessguard->next;
- free(lessguard);
- free(greaterguard);
- return pHead;
- }
- };
-
相关阅读:
正则表达式基本使用
基于jsp+mysql+Spring+mybatis+Springboot的Springboot实现一个在线家庭记账管理平台
MyBatis使用<foreach>标签like查询报错解决
基于SpringBoot+Vue+uniapp的高校疫情管理系统(源码+lw+部署文档+讲解等)
低代码平台深度剖析
Visual Studio Code <1.71.1 权限提升漏洞
30 - 时间模块与随机模块(含一阶段测试编程题)
基于SSM+Vue的物流管理系统的设计与实现
Java:Java有多流行,有哪些主要应用程序?
flutter 中最详细的继承,多态,接口讲解
-
原文地址:https://blog.csdn.net/weixin_67900732/article/details/126205650