Difficulty: Hard
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.
Note:
- 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.
Subscribe to see which companies asked this question
Hide Tags
Show Similar Problems
--------------------------------------------------------------------------
-------------------------------------------------------------------------
Binary search:
turn left or right based on the index instead of the data. See following procedure:
when m=1, we count the # of value in data who is <=m; if the count less than m, turn left, otherwise turn right. Returned value is L in index, not in data!
//////////////////////////////////////////////
//////codes
class Solution {
public:
int
findDuplicate(vector<int>&
nums) {
int low =
1, high = nums.size() - 1;
while (low <= high) {
int mid =
low + (high - low) * 0.5;
int cnt =
0;
for (auto a : nums) {
if (a
<= mid) ++cnt;
}
if (cnt
<= mid) low = mid + 1;
else high =
mid - 1;
}
return low;
}
};
No comments:
Post a Comment