【Hot100】LeetCode—287. 寻找重复数

目录

  • 题目
  • [1- 思路](#1- 思路)
  • [2- 实现](#2- 实现)
    • [⭐287. 寻找重复数------题解思路](#⭐287. 寻找重复数——题解思路)
  • [3- ACM 实现](#3- ACM 实现)

题目


1- 思路

  • 快慢指针

2- 实现

⭐287. 寻找重复数------题解思路

java 复制代码
class Solution {
    public int findDuplicate(int[] nums) {
        int slow = nums[0];
        int fast = nums[0];

        // 找到环
        do{
            slow = nums[slow];
            fast = nums[nums[fast]];
        }while(slow!=fast);


        slow = nums[0];
        while(slow!=fast){
            slow = nums[slow];
            fast = nums[fast];
        }
        return slow;
    }
}

3- ACM 实现

java 复制代码
public class duplicateNum {
    public static int findDuplicate(int[] nums){
        // 快慢指针
        int slow = nums[0];
        int fast = nums[0];

        // 出发
        do{
            slow = nums[slow];
            fast = nums[nums[fast]];

        }while(slow!=fast);

        slow = nums[0];
        while(slow!=fast){
            slow = nums[slow];
            fast = nums[fast];
        }
        return slow;
    }

    public static void main(String[] args) {
        Scanner sc = new Scanner(System.in);
        int n = sc.nextInt();
        int[] nums = new int[n];
        for(int i = 0 ; i < n;i++){
            nums[i] = sc.nextInt();
        }
        System.out.println("结果是"+findDuplicate(nums));
    }
}
相关推荐
2401_85791829几秒前
实时数据处理中的C++应用
开发语言·c++·算法
2401_88456324几秒前
C++中的装饰器模式实战
开发语言·c++·算法
MicroTech20255 分钟前
微算法科技(NASDAQ :MLGO)抗量子区块链技术:筑牢量子时代的数字安全防线
科技·算法·区块链
Ivanqhz7 分钟前
图着色寄存器分配算法(Graph Coloring)
开发语言·javascript·python·算法·蓝桥杯·rust
Elsa️7469 分钟前
洛谷p5718 复习下快速排序和堆排序
数据结构·算法·排序算法
Frostnova丶12 分钟前
LeetCode 3567.子矩阵的最小绝对差
算法·leetcode·矩阵
夏日听雨眠13 分钟前
文件学习9
数据结构·学习·算法
华农DrLai14 分钟前
什么是自动Prompt优化?为什么需要算法来寻找最佳提示词?
人工智能·算法·llm·nlp·prompt·llama
黎阳之光14 分钟前
十五五智赋新程 黎阳之光以AI硬核技术筑造产业数智底座
大数据·人工智能·算法·安全·数字孪生
2401_8914821716 分钟前
C++中的原型模式
开发语言·c++·算法