알고리즘 - 검색 건너뛰기
예를 들어 크기가 n인 배열 arr[]과 크기가 m인 블록(점프 대상)이 있다고 가정합니다. 그런 다음 arr[0], arr[m], arr[2m]... ..arr[km] 등의 인덱스를 검색합니다. 간격(arr [km]
)을 찾으면다음 배열을 고려합니다: (0,1,1,2,3,5,8,13,21,34,55,89,144,233,377,610). 배열의 길이는 16입니다. 건너뛸 블록 크기가 4라고 가정하면 건너뛰기 검색은 다음 단계에서 55를 찾습니다.
1단계: 인덱스 0에서 인덱스 4로 점프합니다.
2단계: 인덱스 4에서 인덱스 8로 점프합니다.
3단계: 인덱스 8에서 인덱스 16으로 점프합니다.
4단계: 인덱스 16의 요소가 55보다 크므로 인덱스 9로 한 단계 뒤로 이동합니다.
5단계: 인덱스 9에서 선형 검색을 수행하여 요소 55를 가져옵니다.
건너뛸 최적의 청크 크기는 얼마인가요?
최악의 경우, 마지막으로 확인한 값이 검색 중인 요소보다 큰 경우 n/m 점프를 수행하고 선형 검색으로 m-1 비교를 수행해야 합니다. 따라서 최악의 경우 총 비교 횟수는 ((n/m) + m-1)이 됩니다. m =√n일 때 함수의 값 ((n/m) + m-1)은 최소값이 됩니다. 따라서 가장 좋은 단계 크기는 m = √n입니다.
출력:
번호 55는 인덱스 10에 있습니다
시간 복잡도: O(√n)
보조공간 : O(1)
주의:
이 검색은 정렬된 배열에서만 작동합니다.
건너뛸 청크의 최적 크기는 O(√n)입니다. 이는 점프 탐색을 O(√n) 시간 복잡도로 만듭니다.
스킵 검색의 시간 복잡도는 선형 검색((O(n)))과 이진 검색(O(Log n)
) 사이입니다.
이진 검색은 점프 검색보다 낫지만 점프 검색은 한 번만 탐색한다는 장점이 있습니다(이진 검색은 검색되는 요소가 가장 작은 요소이거나 가장 작은 요소보다 작다는 점을 고려하여 최대 0(Log n) 점프가 필요할 수 있습니다). 따라서 점프 백 비용이 많이 드는 시스템에서는 점프 검색을 사용합니다.
위 내용은 알고리즘 - 검색 건너뛰기의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

핫 AI 도구

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

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

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

Clothoff.io
AI 옷 제거제

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

인기 기사

뜨거운 도구

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

SublimeText3 중국어 버전
중국어 버전, 사용하기 매우 쉽습니다.

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

드림위버 CS6
시각적 웹 개발 도구

SublimeText3 Mac 버전
신 수준의 코드 편집 소프트웨어(SublimeText3)

Linux 시스템의 5 가지 기본 구성 요소는 다음과 같습니다. 1. Kernel, 2. System Library, 3. System Utilities, 4. 그래픽 사용자 인터페이스, 5. 응용 프로그램. 커널은 하드웨어 리소스를 관리하고 시스템 라이브러리는 사전 컴파일 된 기능을 제공하며 시스템 유틸리티는 시스템 관리에 사용되며 GUI는 시각적 상호 작용을 제공하며 응용 프로그램은 이러한 구성 요소를 사용하여 기능을 구현합니다.

git 저장소 주소를 보려면 다음 단계를 수행하십시오. 1. 명령 줄을 열고 리포지토리 디렉토리로 이동하십시오. 2. "git remote -v"명령을 실행하십시오. 3. 출력 및 해당 주소에서 저장소 이름을 봅니다.

메모장은 Java 코드를 직접 실행할 수는 없지만 다른 도구를 사용하여 명령 줄 컴파일러 (Javac)를 사용하여 Bytecode 파일 (filename.class)을 생성하면 달성 할 수 있습니다. Java Interpreter (Java)를 사용하여 바이트 코드를 해석하고 코드를 실행하고 결과를 출력하십시오.

Sublime에서 코드를 실행하는 6 가지 방법이 있습니다. 핫키, 메뉴, 빌드 시스템, 명령 줄, 기본 빌드 시스템 설정 및 사용자 정의 빌드 명령, 프로젝트/파일을 마우스 오른쪽 단추로 클릭하여 개별 파일/프로젝트를 실행합니다. 빌드 시스템 가용성은 숭고한 텍스트 설치에 따라 다릅니다.

Linux의 주요 용도에는 다음이 포함됩니다. 1. 서버 운영 체제, 2. 임베디드 시스템, 3. 데스크탑 운영 체제, 4. 개발 및 테스트 환경. Linux는이 분야에서 뛰어나 안정성, 보안 및 효율적인 개발 도구를 제공합니다.

Laravel을 설치하려면 다음 단계를 순서대로 수행하십시오. Composer 설치 (MacOS/Linux 및 Windows) 설치 LARAVEL 설치 프로그램 새 프로젝트 시작 서비스 액세스 애플리케이션 (URL : http://127.0.1:8000) 데이터베이스 연결 (필요한 경우)을 설정하십시오.

GIT 소프트웨어 설치 단계는 다음 단계가 포함됩니다. 설치 패키지를 다운로드하고 설치 패키지를 실행하여 설치 구성 GIT 설치 GIT BASH (Windows 만)를 확인하십시오.

Sublime Text는 일반적으로 사용되는 (저장, 복사, 절단 등), 편집 (압입, 서식 등), 탐색 (프로젝트 패널, 파일 브라우징 등) 및 바로 가기 찾기 및 교체를 포함하여 개발 효율성을 향상시키기위한 바로 가기를 제공합니다. 이러한 바로 가기 키를 사용하는 능력은 Sublime의 효율성을 크게 향상시킬 수 있습니다.
