찾다
JavaJava시작하기Java는 이진 검색을 구현합니다.

Java는 이진 검색을 구현합니다.

Dec 30, 2019 am 11:50 AM
java성취하다

Java는 이진 검색을 구현합니다.

이진 검색이란 무엇입니까?

생체 인식 검색도 지정된 요소를 순서대로 찾고, 최소 인덱스(low)와 최대 인덱스(height-1)를 설정하고 중간 값 mid(( low+height-1)/2), 이러한 종류의 검색에서는 중간 값이 지정된 요소보다 작으면 low=mid+1로 하고, 중간 값이 지정된 요소보다 크면 height=mid-로 둡니다. 1;

코드 구현: (무료 비디오 튜토리얼 공유: java 비디오 튜토리얼)

import java.util.ArrayList;
import java.util.Arrays;
import java.util.Collections;
import java.util.List;
import java.util.Scanner;
 
public class Main2 {
	public static void main(String[] args) {
		Scanner sc = new Scanner(System.in);
				int arr[] = { 2, 5, 6, 8, 9, 4, 7 };
				Arrays.sort(arr);
				int deix(索引) = getxiabiao(arr, 7);
				
			}
			public static int getxiabiao(int[] arr, int key) {
				int heigh = arr.length-1;
				int low = 0;
				int mid = 0;
				while (low <= heigh) {
					mid = low + (heigh - low)/2;
					if (arr[mid] == key) {
						return mid;
					} else if (arr[mid] < key) {
						low = mid + 1;
					} else if (arr[mid] > key) {
						heigh = mid - 1;
					}
				}
				return -1;
			}
		}

중간 값을 설정하는 방법에는 두 가지가 있습니다.

알고리즘 1: mid = (낮음 + 높음) / 2

알고리즘 2 : mid = low + (high – low)/2

얼핏 보면 알고리즘 1은 추출하고 나면 알고리즘 2도 알고리즘 1과 다르지 않습니다. 그러나 실제로는 차이가 존재합니다.

알고리즘 1의 접근 방식은 극단적인 경우 (낮음 + 높음)의 오버플로가 발생할 위험이 있으며, 이로 인해 잘못된 mid 결과가 발생하고 프로그램 오류가 발생할 수 있습니다. 그러나 알고리즘 2는 계산된 mid가 반드시 일치함을 보장할 수 있습니다. low보다 크고 high보다 작으면 오버플로 문제가 없습니다.

추천 관련 기사 및 튜토리얼: Java 입문 튜토리얼

위 내용은 Java는 이진 검색을 구현합니다.의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명
이 기사는 CSDN에서 복제됩니다. 침해가 있는 경우 admin@php.cn으로 문의하시기 바랍니다. 삭제

핫 AI 도구

Undresser.AI Undress

Undresser.AI Undress

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

AI Clothes Remover

AI Clothes Remover

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

Undress AI Tool

Undress AI Tool

무료로 이미지를 벗다

Clothoff.io

Clothoff.io

AI 옷 제거제

Video Face Swap

Video Face Swap

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

뜨거운 도구

Dreamweaver Mac版

Dreamweaver Mac版

시각적 웹 개발 도구

SecList

SecList

SecLists는 최고의 보안 테스터의 동반자입니다. 보안 평가 시 자주 사용되는 다양한 유형의 목록을 한 곳에 모아 놓은 것입니다. SecLists는 보안 테스터에게 필요할 수 있는 모든 목록을 편리하게 제공하여 보안 테스트를 더욱 효율적이고 생산적으로 만드는 데 도움이 됩니다. 목록 유형에는 사용자 이름, 비밀번호, URL, 퍼징 페이로드, 민감한 데이터 패턴, 웹 셸 등이 포함됩니다. 테스터는 이 저장소를 새로운 테스트 시스템으로 간단히 가져올 수 있으며 필요한 모든 유형의 목록에 액세스할 수 있습니다.

mPDF

mPDF

mPDF는 UTF-8로 인코딩된 HTML에서 PDF 파일을 생성할 수 있는 PHP 라이브러리입니다. 원저자인 Ian Back은 자신의 웹 사이트에서 "즉시" PDF 파일을 출력하고 다양한 언어를 처리하기 위해 mPDF를 작성했습니다. HTML2FPDF와 같은 원본 스크립트보다 유니코드 글꼴을 사용할 때 속도가 느리고 더 큰 파일을 생성하지만 CSS 스타일 등을 지원하고 많은 개선 사항이 있습니다. RTL(아랍어, 히브리어), CJK(중국어, 일본어, 한국어)를 포함한 거의 모든 언어를 지원합니다. 중첩된 블록 수준 요소(예: P, DIV)를 지원합니다.

SublimeText3 영어 버전

SublimeText3 영어 버전

권장 사항: Win 버전, 코드 프롬프트 지원!

VSCode Windows 64비트 다운로드

VSCode Windows 64비트 다운로드

Microsoft에서 출시한 강력한 무료 IDE 편집기