Search & Sort

先人の知恵を借りる。「車輪の再発明」をしないために。

Binary Search
ソート済みのデータから、中央を調べて半分ずつ候補を絞る探索法。O(log n)。

Binary Search (O(log n))

電話帳をめくるように探す。100万件あっても20回以内で見つかる。前提条件は「ソート済み」であること。

binary-search.js
function binarySearch(arr, target) {
let left = 0;
let right = arr.length - 1;
while (left <= right) {
const mid = Math.floor((left + right) / 2);
if (arr[mid] === target) return mid;
if (arr[mid] < target) {
left = mid + 1; // Look Right
} else {
right = mid - 1; // Look Left
}
}
return -1;
}