인프런 커뮤니티 질문&답변

픽린님의 프로필 이미지
픽린

작성한 질문수

홍정모의 따라하며 배우는 C언어 (부록)

17.15 이진 탐색

이진 탐색: 탐색 실패하는 경우 어째서 first > last인 경우가 나오나요?

작성

·

269

0

17.15강 이진탐색 강의의 13:10부분입니다.


이진탐색에서 만약 탐색을 실패하는 경우 어째서 first >last라는 상황이 발생하는지 잘 모르겠습니다.

반복문을 반복해야할 상황이(탐색해야할 상황이) first <= last인 상황이라는 것을 알겠지만, first > last가 되는 상황은 어떻게 유도되는지 모르겠습니다.

#include <stdio.h>
int BSearch(int ar[], int len, int target) {
int first = 0;
int last = len - 1;
int mid;

while (first <= last) {
mid = (first + last) / 2;

if (target == ar[mid])
return mid;
else {
if (target < ar[mid])
last = mid - 1;
else
first = mid + 1;
} }
return -1;
}

int main(void)
{
int arr[] = { 1,3,5,6,7,9,11,13,15,19 };
int index; index = BSearch(arr, sizeof(arr) / sizeof(int), 3);
if (index == -1)
printf("해당값 없음\n");
else printf("타겟의 위치 : %d\n", index);
return 0;
}

답변 1

0

안녕하세요,

아래 코드가 실행되다보면

last는 mid 기준 1씩 감소

first는 mid 기준 1씩 증가할 수 있음을 보입니다.

만일 last와 first가 동일한 값을 가지고 있을 경우

그리고 아래 중 하나의 코드가 실행될 경우

first 와 last 값을 역전될 수 있습니다.

    else {
      if (target < ar[mid])
        last = mid - 1;
      else
        first = mid + 1;
픽린님의 프로필 이미지
픽린

작성한 질문수

질문하기