栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 软件开发 > 后端开发 > Java

2021-11-01:寻找重复数。给定一个包含 n + 1 个整数的数组 nums ,其数字都在 1 到 n 之间(包括 1 和 n),可知至少存在一个重复的整数。假设 nums 只有 一个重复的整数

Java 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

2021-11-01:寻找重复数。给定一个包含 n + 1 个整数的数组 nums ,其数字都在 1 到 n 之间(包括 1 和 n),可知至少存在一个重复的整数。假设 nums 只有 一个重复的整数

2021-11-01:寻找重复数。给定一个包含 n + 1 个整数的数组 nums ,其数字都在 1 到 n 之间(包括 1 和 n),可知至少存在一个重复的整数。假设 nums 只有 一个重复的整数 ,找出 这个重复的数 。你设计的解决方案必须不修改数组 nums 且只用常量级 O(1) 的额外空间。力扣287。

答案2021-11-01:

方法1:快慢指针。
抽象为环形链表求入环节点。
方法2:位操作。此方法对于1到n都有的情况下适用。1到n,不是都有,不适合。

时间复杂度:O(N)。
额外空间复杂度:O(1)。

代码用golang编写。代码如下:

package main

import "fmt"

func main() {
    if true {
        nums := []int{1, 2, 3, 2, 4, 5, 6}
        ret := findDuplicate(nums)
        fmt.Println(ret)
    }
    if true {
        nums := []int{1, 2, 3, 2, 4, 5, 6}
        ret := findDuplicate2(nums)
        fmt.Println(ret)
    }
}

func findDuplicate(nums []int) int {
    if len(nums) < 2 {
        return -1
    }
    slow := nums[0]
    fast := nums[nums[0]]
    for slow != fast {
        slow = nums[slow]
        fast = nums[nums[fast]]
    }
    fast = 0
    for slow != fast {
        fast = nums[fast]
        slow = nums[slow]
    }
    return slow
}

func findDuplicate2(nums []int) int {
    if len(nums) < 2 {
        return -1
    }
    x1 := 0
    x2 := 0
    for i := 0; i < len(nums); i++ {
        x1 ^= i
        x2 ^= nums[i]
    }
    return x1 ^ x2
}

执行结果如下:


左神java代码

转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/389668.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号