I was asked the following question in my interview yesterday:
Consider a Java or C++ array say X which is sorted and no two elements in it are same. How best can you find an index say i such that element at that index is also i. That is X[i] = i.
As clarification she also gave me an example:
Array X : -3 -1 0 3 5 7
index : 0 1 2 3 4 5
Answer is 3 as X[3] = 3.
The best I could think was a linear search. After the interview I though a lot on this problem but could not find any better solution. My argument is: the element with the required property can be anywhere in the array. So it could also be at the very end of the array so we need to check every element.
I just wanted to confirm from the community here that I’m right. Please tell me I’m right 🙂
This can be done in
O(logN)time andO(1)space by using a slightly modified binary search.Consider a new array
Ysuch thatY[i] = X[i] - iSince the elements in
Xare in increasing order, the elements in thenew array
Ywill be in non-decreasing order. So a binarysearch for
0inYwill give the answer.But creating
Ywill takeO(N)space andO(N)time. So instead ofcreating the new array you just modify the binary search such that a
reference to
Y[i]is replaced byX[i] - i.Algorithm:
Java implementation
C++ implementation