이진 검색 알고리즘을 사용하는 프로그램의 시간 복잡도는 "로그 수준"입니다. 이진 검색은 매우 효율적인 검색 방법입니다. 알고리즘 복잡도는 while 루프의 수입니다. 시간 복잡도는 "O(h)=O(log2n)"으로 표현됩니다.
이 튜토리얼의 운영 환경: Windows 7 시스템, Dell G3 컴퓨터.
이진 검색 알고리즘을 사용하는 프로그램의 시간 복잡도는 "로그 수준"입니다.
관련 추천: "Programming Learning"
이진 검색은 이진 검색(Binary Search)이라고도 하는데, 보다 효율적인 검색 방법입니다. 그러나 이진 검색을 위해서는 선형 테이블이 순차적 저장 구조를 채택해야 하며 테이블의 요소는 키워드에 따라 순서대로 정렬되어야 합니다.
검색 과정:
먼저 테이블의 요소가 오름차순으로 배열되어 있다고 가정하고 테이블의 중간에 기록된 키워드와 검색 키워드를 비교하여 두 개가 같으면 검색에 성공합니다. ; 그렇지 않으면 중간 위치 레코드를 사용하여 테이블을 변경합니다. 앞과 뒤의 두 개의 하위 테이블로 구분됩니다. 가운데에 기록된 키워드가 검색 키워드보다 큰 경우 이전 하위 테이블을 검색합니다. 그렇지 않으면 후자의 하위 테이블이 추가로 검색됩니다. 조건에 맞는 레코드가 발견되어 검색이 성공할 때까지 또는 하위 테이블이 존재하지 않아 검색이 실패할 때까지 위 프로세스를 반복합니다.
알고리즘 복잡성:
이진 검색의 기본 아이디어는 n 요소를 대략 동일한 두 부분으로 나누고 x=a[n/2]인 경우 a[n/2]를 비교하는 것입니다. x가 발견되면 알고리즘이 종료됩니다.
시간 복잡도는 while 루프의 수입니다.
총 n개의 요소가 있습니다.
는 점차적으로 n, n/2, n/4,...n/2^k(다음에 연산할 나머지 요소 수)를 따릅니다. 여기서 k는 숫자입니다.
n/2^k가 반올림되었으므로 >=1
즉, n/2^k=1
인 경우 k=log2n을 얻을 수 있습니다(2를 밑으로 하는 n의 로그입니다).
그래서 시간 복잡도는 O(h)=O(log2n)
로 표현할 수 있습니다. 다음은 이진 검색 구현을 위한 의사 코드입니다.
BinarySearch(max,min,des) mid-<(max+min)/2 while(min<=max) mid=(min+max)/2 if mid=des then return mid elseif mid >des then max=mid-1 else min=mid+1 return max
반 검색 방법은 이진 검색 방법이라고도 하며 요소 간의 순서 관계를 최대한 활용합니다. 최악의 경우에는 분할 정복 전략을 사용한다. 이 경우 탐색 작업은 O(log n)에 완료될 수 있다. 기본 아이디어는 다음과 같습니다. (배열 요소가 오름차순으로 정렬되어 있다고 가정) n 요소를 대략 같은 수의 두 부분으로 나누고 a[n/2]를 가져와 x=인 경우 찾으려는 x와 비교합니다. a[n/ 2]이면 x가 발견되고 알고리즘이 종료됩니다. x 더 많은 관련 기사를 보려면 PHP 중국어 웹사이트를 방문하세요! !
위 내용은 이진 검색 알고리즘을 사용하는 프로그램의 시간 복잡도는 얼마입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

핫 AI 도구

Undresser.AI Undress
사실적인 누드 사진을 만들기 위한 AI 기반 앱

AI Clothes Remover
사진에서 옷을 제거하는 온라인 AI 도구입니다.

Undress AI Tool
무료로 이미지를 벗다

Clothoff.io
AI 옷 제거제

Video Face Swap
완전히 무료인 AI 얼굴 교환 도구를 사용하여 모든 비디오의 얼굴을 쉽게 바꾸세요!

인기 기사

뜨거운 도구

메모장++7.3.1
사용하기 쉬운 무료 코드 편집기

Atom Editor Mac 버전 다운로드
가장 인기 있는 오픈 소스 편집기

MinGW - Windows용 미니멀리스트 GNU
이 프로젝트는 osdn.net/projects/mingw로 마이그레이션되는 중입니다. 계속해서 그곳에서 우리를 팔로우할 수 있습니다. MinGW: GCC(GNU Compiler Collection)의 기본 Windows 포트로, 기본 Windows 애플리케이션을 구축하기 위한 무료 배포 가능 가져오기 라이브러리 및 헤더 파일로 C99 기능을 지원하는 MSVC 런타임에 대한 확장이 포함되어 있습니다. 모든 MinGW 소프트웨어는 64비트 Windows 플랫폼에서 실행될 수 있습니다.

스튜디오 13.0.1 보내기
강력한 PHP 통합 개발 환경

WebStorm Mac 버전
유용한 JavaScript 개발 도구
