-
Notifications
You must be signed in to change notification settings - Fork 39
/
Copy pathfind_the_duplicate_number.rb
41 lines (36 loc) · 1.03 KB
/
find_the_duplicate_number.rb
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
# https://leetcode.com/problems/find-the-duplicate-number/
#
# Given an array nums containing n + 1 integers where each integer is between
# 1 and n (inclusive), prove that at least one duplicate number must exist.
# Assume that there is only one duplicate number, find the duplicate one.
#
# Notes:
#
# + You must not modify the array (assume the array is read only).
# + You must use only constant, O(1) extra space.
# + Your runtime complexity should be less than O(n2).
# + There is only one duplicate number in the array, but it could be
# repeated more than once.
#
# Credits:
#
# Special thanks to @jianchao.li.fighter for adding this problem and
# creating all test cases.
# @param {Integer[]} nums
# @return {Integer}
def find_duplicate(nums)
start = nums.size
fast, slow = start, start
loop do
fast = nums[nums[fast - 1] - 1]
slow = nums[slow - 1]
break if fast == slow
end
slow = start
loop do
fast = nums[fast - 1]
slow = nums[slow - 1]
break if fast == slow
end
fast
end