Python의 이진 검색(이등분)
요소가 정렬된 목록이나 튜플에 있는지 확인하는 것은 프로그래밍에서 일반적인 작업입니다. Python은 이진 검색을 위한 bisect 모듈을 제공하지만 bisect_left 및 bisect_right 함수는 항목을 찾을 수 없더라도 위치를 반환합니다. 이러한 요구를 해결하기 위해 부울 값을 명시적으로 반환하는 이진 검색의 Python 구현이 도입되었습니다.
제안된 솔루션
binary_search 함수는 정렬된 목록 'a'를 사용합니다. , 검색할 요소 'x', 검색 범위에 대한 선택적인 시작 및 끝 위치 'lo' 및 'hi'. bisect 모듈의 bisect_left 함수를 사용하여 'a' 목록에서 'x'에 대한 삽입 지점 'pos'를 찾습니다.
'pos'가 'hi'보다 작고 'pos'에 있는 요소가 있는 경우 '가 'x'와 같으면 'x'가 발견되고 'pos'가 목록에서 해당 위치의 인덱스로 반환됩니다. 그러나 'pos'가 목록의 끝에 도달하면(예: 'pos'가 'hi'와 같음) 'x'를 찾을 수 없으며 함수는 -1을 반환합니다.
from bisect import bisect_left def binary_search(a, x, lo=0, hi=None): if hi is None: hi = len(a) pos = bisect_left(a, x, lo, hi) # find insertion position return pos if pos != hi and a[pos] == x else -1 # don't walk off the end
사용 예
예를 들어, 정렬된 목록 'a'와 검색할 요소 'x'가 주어지면 Binary_search 함수를 사용할 수 있습니다.
result = binary_search(a, x) if result == -1: print("Element not found") else: print("Element found at index", result)
이 간결한 Python 함수는 이진 검색의 단순성과 효율성을 유지하면서 정렬된 목록에서 요소 존재 확인을 위한 이진 검색을 수행하는 편리한 방법을 제공합니다.
위 내용은 이 Python 이진 검색 기능은 요소를 찾나요?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

2 시간 이내에 Python의 기본 프로그래밍 개념과 기술을 배울 수 있습니다. 1. 변수 및 데이터 유형을 배우기, 2. 마스터 제어 흐름 (조건부 명세서 및 루프), 3. 기능의 정의 및 사용을 이해하십시오. 4. 간단한 예제 및 코드 스 니펫을 통해 Python 프로그래밍을 신속하게 시작하십시오.

Python은 웹 개발, 데이터 과학, 기계 학습, 자동화 및 스크립팅 분야에서 널리 사용됩니다. 1) 웹 개발에서 Django 및 Flask 프레임 워크는 개발 프로세스를 단순화합니다. 2) 데이터 과학 및 기계 학습 분야에서 Numpy, Pandas, Scikit-Learn 및 Tensorflow 라이브러리는 강력한 지원을 제공합니다. 3) 자동화 및 스크립팅 측면에서 Python은 자동화 된 테스트 및 시스템 관리와 같은 작업에 적합합니다.

2 시간 이내에 파이썬의 기본 사항을 배울 수 있습니다. 1. 변수 및 데이터 유형을 배우십시오. 이를 통해 간단한 파이썬 프로그램 작성을 시작하는 데 도움이됩니다.

10 시간 이내에 컴퓨터 초보자 프로그래밍 기본 사항을 가르치는 방법은 무엇입니까? 컴퓨터 초보자에게 프로그래밍 지식을 가르치는 데 10 시간 밖에 걸리지 않는다면 무엇을 가르치기로 선택 하시겠습니까?

Fiddlerevery Where를 사용할 때 Man-in-the-Middle Reading에 Fiddlereverywhere를 사용할 때 감지되는 방법 ...

Python 3.6에 피클 파일로드 3.6 환경 보고서 오류 : modulenotfounderror : nomodulename ...

경치 좋은 스팟 댓글 분석에서 Jieba Word 세분화 문제를 해결하는 방법은 무엇입니까? 경치가 좋은 스팟 댓글 및 분석을 수행 할 때 종종 Jieba Word 세분화 도구를 사용하여 텍스트를 처리합니다 ...

정규 표현식을 사용하여 첫 번째 닫힌 태그와 정지와 일치하는 방법은 무엇입니까? HTML 또는 기타 마크 업 언어를 다룰 때는 정규 표현식이 종종 필요합니다.


핫 AI 도구

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

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

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

Clothoff.io
AI 옷 제거제

AI Hentai Generator
AI Hentai를 무료로 생성하십시오.

인기 기사

뜨거운 도구

ZendStudio 13.5.1 맥
강력한 PHP 통합 개발 환경

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

안전한 시험 브라우저
안전한 시험 브라우저는 온라인 시험을 안전하게 치르기 위한 보안 브라우저 환경입니다. 이 소프트웨어는 모든 컴퓨터를 안전한 워크스테이션으로 바꿔줍니다. 이는 모든 유틸리티에 대한 액세스를 제어하고 학생들이 승인되지 않은 리소스를 사용하는 것을 방지합니다.

SublimeText3 Linux 새 버전
SublimeText3 Linux 최신 버전

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