刷了有关链表的一些算法题后,我发现其中用到快慢指针的题不少,像中间节点,倒数第n个节点以及链表成环
链表成环问题我只前发过两篇博客详细的讲了一下
跳转链接 https://blog.csdn.net/lmy050813/article/details/136082903?utm_source=app&app_version=6.2.8&code=app_1562916241&uLinkId=usr1mkqgl919blen http://t.csdnimg.cn/e8p9P
今天就来说一下另外两道题
题目链接
leecode链表的中间节点 https://leetcode.cn/problems/middle-of-the-linked-list/description/ 牛客链表中倒数第k个节点 https://www.nowcoder.com/practice/529d3ae5a407492994ad2a246518148a?tab=note
首先这两道题都用到了快慢指针,而且及其相似,第一道题让慢指针走一步,快指针走两步,快指针走到空时,慢指针指向中间节点
第二道题同理,快指针先走k步,然后快慢指针一起走,快指针走向空,慢指针指向倒数第k个节点
下面分别是第一二道题的代码
代码语言:javascript复制/**
* Definition for singly-linked list.
* struct ListNode {
* int val;
* struct ListNode *next;
* };
*/
struct ListNode* middleNode(struct ListNode* head) {
struct ListNode *slow, *fast;
slow = fast = head;
while(fast && fast->next)
{
fast = fast->next->next;
slow = slow->next;
}
return slow;
}
代码语言:javascript复制/**
* struct ListNode {
* int val;
* struct ListNode *next;
* };
*/
/**
*
* @param pListHead ListNode类
* @param k int整型
* @return ListNode类
*/
struct ListNode* FindKthToTail(struct ListNode* pListHead, int k ) {
// write code here
struct ListNode* slow = pListHead, *fast = pListHead;
if(k == 0)
return NULL;
while(fast)
{
if(k > 0)
{
fast = fast->next;
k--;
if(k == 1)
{
if(fast == NULL)
return NULL;
}
}
else
{
slow = slow->next;
fast = fast->next;
}
}
return slow;
}
总结
关于这些问题,我们不难发现,在链表中快慢指针的应用相对频繁,在后续对链表的学习和对有关链表的算法题进行公克的时候,不妨多往快慢指针方面去想想