>백엔드 개발 >C#.Net 튜토리얼 >배열 요소를 찾기 위해 C 언어로 이분법을 구현하는 방법

배열 요소를 찾기 위해 C 언어로 이분법을 구현하는 방법

coldplay.xixi
coldplay.xixi원래의
2021-03-17 14:59:325736검색

C 언어 이분법을 사용하여 배열 요소 찾기: 1. 재귀 알고리즘, 코드는 [if(a[mid] == key) return mid]; 2. 비재귀 알고리즘, 코드는 [while( left < right) && a[mid] != 키 )].

배열 요소를 찾기 위해 C 언어로 이분법을 구현하는 방법

이 튜토리얼의 운영 환경: 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 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.