Day18力扣打卡

打卡记录

寻找重复数(双指针)

链接

Floyd判圈法,先用快慢指针以不同速率进行移动,最终一定会出现相遇点,然后在使一指针从初始开始,两指针再以同步调移动,再次相遇的点一定为循环开始的点位。

cpp 复制代码
class Solution {
public:
    int findDuplicate(vector<int>& nums) {
        int slow = 0, fast = 0;
        do {
            slow = nums[slow];
            fast = nums[nums[fast]];
        } while (slow != fast);
        slow = 0;
        while (slow != fast) {
            slow = nums[slow];
            fast = nums[fast];
        }
        return fast;
    }
};
相关推荐
L_090712 分钟前
【C++】异常
开发语言·c++
Frostnova丶12 分钟前
【算法笔记】数学知识
笔记·算法
liulilittle17 分钟前
关于拥塞控制的几点思考
网络·c++·tcp/ip·计算机网络·信息与通信·tcp·通信
吴可可12337 分钟前
AutoCAD 2016与2014二次开发关键差异
算法
雨白2 小时前
哈希:以时间换空间的算法实战
算法
QT-Neal3 小时前
C++ 编码规范
c++
啦啦啦啦啦zzzz3 小时前
数据结构:红黑树理论
数据结构·c++·红黑树
Yolo_TvT3 小时前
C++:默认构造函数
c++
San813_LDD3 小时前
[数据结构]LeetCode学习
数据结构·算法·图论