이진 탐색: 탐색 실패하는 경우 어째서 first > last인 경우가 나오나요?
324
投稿した質問数 22
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;
안녕하세요. 계속 프로젝트를 해야지 하다가 결제하고 환경 설정 중입니다.
0
14
1
Export template 안됨
1
26
2
scanf("%d\n") 의미
0
20
1
필기자료 사라졌나요?(실기 일주일만에 안돼서 재도전-_-)
0
37
2
26년 1회 실기 해설 강의
0
51
2
주소 연산자(&) 간접 지정자(*) 반대 개념
0
33
1
17.12) access violation
0
307
1
finditembyindex 질문드립니다!
0
348
1
19:20 부분에서 질문있습니다.
0
278
1
pnode = pnode->next; 와 pnode->next = pnode;는 같은 것으로 생각해도 될까요?
0
401
2
질문. warning뜨는 이유
0
301
1
링크드 리스트 질문 드립니다.
0
216
1
함수포인터 질문드립니다
0
224
1
강의 내용 질문 드립니다!
0
369
2
노드 주소 순서 관련 질문
0
282
1
질문드립니다!
0
242
1
DeleteAllNodes 에서 질문있습니다.
0
375
5
16:30 질문입니다.
0
343
4
scanf 질문이요!!
0
253
1
12:30 의 ArrayQueue.h
0
292
2
10:10 Add front에서 질문드립니다.
1
362
1
스택 자료구조
0
246
1
변수 count의 활용에 대해 질문이 있습니다.
0
320
1
1번 실행하면 에러가 뜨는데 이유를 모르겠습니다..
0
371
2

