1
有一項任務是找到一個索引,使得A [i] = i在具有非不同元素的有序數組中。數組中具有非奇數的魔術索引
中鼎給出的解決方案是:
static int magicNonDistinct(int[] array, int start, int end) {
if (end < start) return -1;
int mid = start + (end - start)/2;
if (mid < 0 || mid >= array.length) return -1;
int v = array[mid];
if (v == mid) return mid;
int leftEnd = Math.min(v, mid - 1);
int leftRes = magicNonDistinct(array, start, leftEnd);
if (leftRes != -1) return leftRes;
int rightStart = Math.max(v, mid + 1);
int rightRes = magicNonDistinct(array, rightStart, end);
return rightRes;
}
你能指出我的這些指標的理由:
int leftEnd = Math.min(v, mid - 1);
int rightStart = Math.max(v, mid + 1);
在我的實現,這是類似於上面一個,這些指標計算公式如下:
int leftEnd = (mid < v) ? mid - 1 : v;
int rightStart = (mid < v) ? v : mid + 1;
謝謝。
謝謝你的確。 – Kristina