1.求链表的中间节点
题目描述
给定一个头结点为 head 的非空单链表,返回链表的中间结点。
如果有两个中间结点,则返回第二个中间结点。
示例1
输入:[1,2,3,4,5]
输出:此列表中的结点 3
示例2
输入:[1,2,3,4,5,6]
输出:此列表中的结点 4
使用语言: C语言
思路解析:
此题可以使用快慢指针解,给定两个指针指一个快指针fast,一个慢指针slow,使两个指针向分别指向head位置,因为求中间节点所以,快指针一次走两个位置,慢指针一次走一个位置(即快指针走的是慢指针的二倍),所以当快指针走到尾时慢指针刚好走到中间位置,需要注意的是整个循环结束的条件
图解如下:
链表中节点数为奇数,快指针每次走量个位置,在fast->next == NULL 时结束
链表中节点数为偶数,快指针每次走量个位置,在fast == NULL 时结束
代码实现:
struct ListNode* middleNode(struct ListNode* head)
{
//定义快慢两个指针,到head位置
struct ListNode* fast = head;
struct ListNode* slow = head;
while(fast && fast->next)
{
//慢指针一次走一个位置
slow = slow->next;
//快指针一次走两个位置
fast = fast->next->next;
}
return slow;
}
2.求链表中倒数第K个节点
题目描述
输入一个链表,输出该链表中倒数第k个结点。
示例1
输入:3,{1,2,3,4,5,6,7}
输出:{5}
使用语言: C语言
思路解析:
此题思路和求链表的中间节点的思路类似,求链表中的倒数第K个节点,即给定两个指针指一个快指针fast,一个慢指针slow,使两个指针位置相差K,在让两个指针同时走,当快指针走到尾 fast = NULL 时,慢指针的位置就是倒数第K个节点的位置:注意需要将极端情况考虑进去,当倒数第K个数不存在的情况 (5,{1,2,3})
图解如下:
代码实现:
struct ListNode* FindKthToTail(struct ListNode* pListHead, int k )
{
struct ListNode* fast = pListHead;
struct ListNode* slow = pListHead;
//先让两个指针相隔K个节点
for(int i = 0;i < k;++i)
{
//即不存在倒数第K个数的情况
if(fast == NULL)
return NULL;
fast = fast->next;
}
//让两个指针开始同时走
while(fast)
{
slow = slow->next;
fast = fast->next;
}
return slow;
}