C 언어 이분법을 사용하여 배열 요소 찾기: 1. 재귀 알고리즘, 코드는 [if(a[mid] == key) return mid]; 2. 비재귀 알고리즘, 코드는 [while( left < right) && a[mid] != 키 )].
이 튜토리얼의 운영 환경: Windows 7 시스템, c99 버전, DELL G3 컴퓨터.
배열 요소 찾기를 구현하는 C 언어 이분법:
재귀 알고리즘
#include<stdio.h> //二分法实现数组查找 // int recurbinary(int *a, int key, int low, int high) { int mid; if(low > high) return -1; mid = (low + high)/2; if(a[mid] == key) return mid; else if(a[mid] > key) return recurbinary(a,key,low,mid -1); else return recurbinary(a,key,mid + 1,high); }
비재귀 알고리즘
int binary( int *a, int key, int n ) { int left = 0, right = n - 1, mid = 0; mid = ( left + right ) / 2; while( left < right && a[mid] != key ) { if( a[mid] < key ) { left = mid + 1; } else if( a[mid] > key ) { right = mid - 1; } mid = ( left + right ) / 2; } if( a[mid] == key ) return mid; return -1; } int main(void) { int a[10] = {2,4,6,8,10,12,14,16,18,20},t,k,f; scanf("%d",&t); k = recurbinary(a,t,2,20); f = binary(a,t,10); //非递归算法 if(k == -1){ printf("不存在此数\n"); }else{ printf("%-5d是数组第%d个元素\n%-5d数组的第%d个元素",k,k+1,f,f+1); } return 0; }
[관련 학습 권장 사항: C 언어 튜토리얼 동영상]
위 내용은 배열 요소를 찾기 위해 C 언어로 이분법을 구현하는 방법의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!