1533. Find the Index of the Large Integer
1533. Find the Index of the Large Integer
Description
Difficulty: Medium
Related Topics: Array, Binary Search, Interactive
We have an integer array arr
, where all the integers in arr
are equal except for one integer which is larger than the rest of the integers. You will not be given direct access to the array, instead, you will have an API ArrayReader
which have the following functions:
int compareSub(int l, int r, int x, int y)
: where0 <= l, r, x, y < ArrayReader.length()
,l <= r and
x <= y
. The function compares the sum of sub-arrayarr[l..r]
with the sum of the sub-arrayarr[x..y]
and returns:- 1 if
arr[l]+arr[l+1]+...+arr[r] > arr[x]+arr[x+1]+...+arr[y]
. - 0 if
arr[l]+arr[l+1]+...+arr[r] == arr[x]+arr[x+1]+...+arr[y]
. - -1 if
arr[l]+arr[l+1]+...+arr[r] < arr[x]+arr[x+1]+...+arr[y]
.
- 1 if
int length()
: Returns the size of the array.
You are allowed to call compareSub()
20 times at most. You can assume both functions work in O(1)
time.
Return the index of the array arr
which has the largest integer.
Example 1:
1 | Input: arr = [7,7,7,7,10,7,7,7] |
Example 2:
1 | Input: nums = [6,6,12] |
Constraints:
- 2 <= arr.length <= 5 * 105
1 <= arr[i] <= 100
- All elements of
arr
are equal except for one element which is larger than all other elements.
Follow up:
- What if there are two numbers in
arr
that are bigger than all other numbers? - What if there is one number that is bigger than other numbers and one number that is smaller than other numbers?
Hints/Notes
- Binary search
- The key is to handle odd/even number of elements separately
Solution
Language: C++
1 | /** |