前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >链表中快慢指针的应用

链表中快慢指针的应用

作者头像
一枕眠秋雨
发布2024-03-11 18:13:13
720
发布2024-03-11 18:13:13
举报
文章被收录于专栏:司钰秘籍司钰秘籍

刷了有关链表的一些算法题后,我发现其中用到快慢指针的题不少,像中间节点,倒数第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;
}

总结

关于这些问题,我们不难发现,在链表中快慢指针的应用相对频繁,在后续对链表的学习和对有关链表的算法题进行公克的时候,不妨多往快慢指针方面去想想

本文参与 腾讯云自媒体分享计划,分享自作者个人站点/博客。
原始发表:2024-02-16,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 题目链接
  • 总结
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档