이진 탐색에 대한 두 가지 코드.
# 실행 조건
- 유일한 값들이어야 함 (중복x).
- 오름차순 정렬 후 실행해야 함.
# 구현 방식
- 재귀함수 (bsearch_recursive)
- while 반복문 (bsearch_loop)
#include <stdio.h> #include "bsearch.c" void bbsort(int *arr, int length); int bsearch_recursive(int *arr, int begin, int end, int target); int bsearch_loop(int *arr, int target, int length); int main( ) { int arr[] = {11, 9, 1, 5, 15, 3, 7, 13}; int target = 7; int result; int length; length = sizeof(arr)/sizeof(int); bbsort(arr, length); //By Recursive result = bsearch_recursive(arr, 0, length-1, target); //By Loop result = bsearch_loop(arr, length, target); if(result == -1) { printf("Not Found. "); } else { for( int i=0 ; i<length ; ++i ) { printf( "%d ", arr[i] ); } printf(" Found Index : %d. ", result); } return 0; }
No. | Category | Subject | Author | Date | Views |
---|---|---|---|---|---|
» | Develop | [c] 이진 탐색 두 가지 코드 (재귀/반복) | hooni | 2015.06.26 | 982 |
516 | Develop | [c] 이진트리(binary tree) 샘플소스 (삽입, 삭제, 운행) | hooni | 2003.04.23 | 7847 |
515 | Develop | [c] 이진트리(binary tree)의 운행.. | hooni | 2003.04.23 | 8315 |
514 | Develop | [c] 이진트리(binary tree)의 특성 | hooni | 2003.04.23 | 9644 |
513 | Develop | [c] 이진트리/트리 순회법 코드(전위/중위/후위) 5 | hooni | 2015.07.02 | 21069 |
512 | Develop | [c] 자료구조 그래프(graph) 소스코드 - 확인해볼 것.. | hooni | 2013.04.23 | 8011 |
511 | Develop | [c] 재미있는 코딩.. | hooni | 2003.04.23 | 21422 |
510 | Develop | [c] 전위 표기법으로 연산 예제.. | hooni | 2013.04.23 | 9326 |
509 | Develop | [c] 정사각배열의 서브 배열의 최대 값 구하기 | hooni | 2003.04.23 | 7049 |
508 | Develop | [c] 정수를 2진수로 변환 (재귀,비트연산) | hooni | 2003.04.23 | 7609 |
507 | Develop | [c] 지나가는 패킷 잡기 | hooni | 2003.04.23 | 8870 |
506 | Develop | [c] 지폰(gphone) 소스.. 수정(암호화) | hooni | 2013.04.23 | 7448 |