数据结构之“快慢指针”

一、快慢指针

快慢指针是解决链表环问题的一个常见技巧

在这个方法中,我们设置两个指针,一个快指针(每次移动两步)和一个慢指针(每次移动一步)

二、"链表的中间结点"

1、题目:

2、解题思路:

通过快慢指针找到中间节点,快指针每次走两步,慢指针每次走一步,当快指针走到结尾的时候,慢指针正好走到中间位置

3、代码实现:

cpp 复制代码
/**
 * Definition for singly-linked list.
 * struct ListNode {
 *     int val;
 *     struct ListNode *next;
 * };
 */
struct ListNode* middleNode(struct ListNode* head) {
    struct ListNode *fast;
    struct ListNode *slow;
    fast = slow = head;
    while(fast && fast->next)
    {
        slow = slow->next;
        fast = fast->next->next;
    }
    return slow;
}

4、测试用例:

三、"环形链表"

1、题目:

2、解题思路:

定义快慢指针fast,slow, 如果链表确实有环,fast指针一定会在环内追上slow指针

3、代码实现:

cpp 复制代码
/**
 * Definition for singly-linked list.
 * struct ListNode {
 *     int val;
 *     struct ListNode *next;
 * };
 */
bool hasCycle(struct ListNode *head) {
    if(head == NULL || head->next == NULL)
    {
        return false;
    }
    struct ListNode *fast;
    struct ListNode *slow;
    fast = head->next;
    slow = head;
    while(slow != fast)
    {
        if(fast == NULL || fast->next == NULL)
        {
            return false;
        }
        slow = slow->next;
        fast = fast->next->next;
    }
    return true;
}

4、测试用例:

微语:迎着扑面而来的风,点点星光,以及街道两边那道无限往外延伸、延至天边的光

相关推荐
qyzm9 分钟前
Codeforces Round 1073 (Div. 2)
数据结构·python·算法
jieyucx9 分钟前
Go 零基础数据结构:链表的增删改查(像串珠子一样简单)
数据结构·链表·golang
深邃-2 小时前
【数据结构与算法】-二叉树(2):实现顺序结构二叉树(堆的实现),向上调整算法,向下调整算法,堆排序,TOP-K问题
数据结构·算法·二叉树·排序算法·堆排序··top-k
叼烟扛炮10 小时前
C++第二讲:类和对象(上)
数据结构·c++·算法·类和对象·struct·实例化
MegaDataFlowers13 小时前
206.反转链表
数据结构·链表
CN-Dust14 小时前
【C++】while语句例题专题
数据结构·c++·算法
xieliyu.17 小时前
Java手搓数据结构:从零模拟实现无头双向非循环链表
java·数据结构·链表
如何原谅奋力过但无声18 小时前
【灵神高频面试题合集01-03】相向双指针、滑动窗口
数据结构·python·算法·leetcode
jieyucx19 小时前
Go 数据结构入门:线性表、顺序表、链表
数据结构·链表·golang
阿维的博客日记19 小时前
zset为什么要用到skiplist+Dict的数据结构
数据结构·skiplist