리스트의 첫 번째 원소부터 마지막 원소까지 하나씩 순차적으로 탐색
function linearSearch(arr, target) {
for (let i = 0; i < arr.length; i++) {
if (arr[i] === target) return i; // 값이 발견되면 인덱스 반환
}
return -1; // 값이 없으면 -1 반환
}
console.log(linearSearch([4, 2, 9, 7, 1], 7)); // 3
정렬된 리스트에서 중간 값을 기준으로 절반씩 탐색 범위를 줄여나가는 방법
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;
else right = mid - 1;
}
return -1;
}
console.log(binarySearch([1, 2, 4, 7, 9], 7)); // 3