作者:旧梦拾遗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;
- }
- };

-
相关阅读:
MySQL建表操作和用户权限
Java之Stream流及方法引用的详细解析二
Oracle实时同步技术
【C++ Efficiency】理解虚函数、多重继承、虚基类和RTTI
使用Pytorch构建神经网络
编译正常运行,打jar包运行报错(找不到文件路径)
分组后过滤再合并组成员
Unity3D XML与Properties配置文件读取详解
Tiktok上号称能拿百万年薪的Java性能调优笔记,我学完了先去试水
字节跳动社招内推,长期有效,长期有效,长期有效
-
原文地址:https://blog.csdn.net/weixin_67900732/article/details/126205650