찾다
백엔드 개발파이썬 튜토리얼배열의 요소를 검색하는 Python 프로그램

배열의 요소를 검색하는 Python 프로그램

Sep 17, 2023 pm 07:45 PM
파이썬 프로그램검색 요소배열 검색

배열의 요소를 검색하는 Python 프로그램

파이썬에서는 주로 주로 두 가지 검색 알고리즘을 사용합니다. 그 중 첫 번째는 선형 검색이고 두 번째는 이진 검색입니다.

이 두 가지 기술은 주로 주어진 배열이나 주어진 목록에서 요소를 검색하는 데 사용됩니다. 요소를 검색하는 동안 모든 종류의 알고리즘에서 따를 수 있는 두 가지 방법론이 있습니다. 그 중 하나는 재귀적 접근 방식이고 다른 하나는 반복적 접근 방식입니다. 두 가지 접근 방식 모두에서 두 가지 알고리즘을 논의하고 유사한 문제를 해결해 보겠습니다.

선형 검색

선형 검색 기술은 순차 검색이라고도 합니다. “순차 검색”이라는 이름의 의미는 이 검색 알고리즘이 따르는 프로세스에 의해 확실히 정당화됩니다. Python에서 배열이나 목록 내의 요소를 찾기 위해 사용되는 방법 또는 기술입니다.

ㅋㅋㅋ经常使用线性搜索的主要原因。

算법

  • 1단계 − 원하는 요소와 주어진 배열에 있는 각 요소를 비교하여 순차적인 순서로 요소를 검색합니다.

  • 步骤 2 − 如果找到所需的元素,则会将元素的索引或位置显示给用户。

  • 3단계 − 배열 내에 요소가 없으면 사용자에게 해당 요소를 찾을 수 없다는 알림이 표시됩니다. 이런 식으로 알고리즘이 처리됩니다.

일반적으로 선형 검색 알고리즘은 각 요소를 확인하고 비교하기 때문에 작은 배열이나 크기가 100 이하인 작은 목록에 비교적 적합하고 효율적입니다.

  • 如果所需元素位于数组的最后位置,将会消耗更多时间。

  • 线性搜索算法에서 最佳情况下的时间复杂島为“O(1)”。 0”。

  • 평균적인 경우 선형 검색 알고리즘의 시간 복잡도는 “O(n)”입니다. 이 경우 요소는 배열의 중간 위치에 존재합니다. 즉, 인덱스 " (n – 1 ) / 2 " 또는 " (( n – 1 ) / 2 )+ 1 "을 사용합니다.

  • 최악의 경우 선형 검색 알고리즘의 시간 복잡도는 “O(n)”입니다. 이 경우 요소는 배열의 마지막 위치, 즉 인덱스 “n-1”에 표시됩니다.

아래면의 示例中에서, 우리는 们将school习使用线性搜索에서 数组中查找元素的过程。

으아아아

출력

上述程序的输如下:

으아아아

예(재귀)

아래면의 例子中에서, 우리는 们将school习使用递归方法에서 数组中进行线性搜索的过程。

으아아아

출력

上述程序的输如下:

으아아아

이진 검색

이분법은 동일하지 않습니다. ㅋㅋㅋ考虑,它首先被排序,然后算法被应用于数组。

算법

    步骤 1
  • − 对数组进行排序是第一步。

  • 2단계
  • − 배열이 정렬된 후 배열은 두 부분으로 간주됩니다. 절반은 정렬된 배열의 첫 번째 요소부터 중간 요소까지이고, 두 번째 절반은 정렬된 배열의 중간 요소 다음 요소부터 마지막 ​​요소까지입니다.

  • 3단계
  • − 키 요소(검색 대상 요소를 키 요소라고 함)를 정렬된 배열의 중간 요소와 비교합니다.

  • 4단계
  • − 키 요소가 정렬된 배열의 중간 요소보다 작거나 같을 경우, 키 요소가 중간 요소보다 작으므로 후반부 요소는 더 이상 무시됩니다. 따라서 해당 요소는 첫 번째 요소와 중간 요소 사이에 반드시 존재해야 합니다.

  • 6단계
  • − 키 요소가 중간 요소보다 큰 경우 정렬된 배열의 전반부는 무시되고 중간 요소부터 마지막 ​​요소까지의 요소가 고려됩니다.

  • 7단계
  • − 해당 요소 중 핵심 요소를 다시 절반 배열의 중간 요소와 비교하고 동일한 절차를 반복합니다. 핵심 요소가 절반 배열의 중간 요소보다 크면 첫 번째 절반은 무시됩니다.

  • 第8步 - 如果关键元素小于或等于被分割数组的中间元素,则被分割数组的后半部分将被忽略。通过这种方式,元素将在数组的任意一半中进行搜索。

因此,与线性搜索相比,复杂度减少了一半或更多,因为有一半的元素将在第一步中被移除或不被考虑。二分搜索的最佳情况时间复杂度为“O(1)”。二分搜索的最坏情况时间复杂度为“O(logn)”。这就是二分搜索算法的工作原理。让我们考虑一个例子,并应用二分搜索算法来找出数组中的关键元素。

Example

In this example, we are going to learn about the process of searching an element in an array using Binary search in recursive approach.

def recursive_binary(arr, first, last, key_element):
   if first <= last:
      mid = (first + last) // 2 
   if arr[mid] == key_element:
      return mid
   elif arr[mid] > key_element:
      return recursive_binary(arr, first, mid - 1, key_element)
   elif arr[mid] < key_element:  
      return recursive_binary(arr, mid + 1, last, key_element)  
   else:  
      return -1 

arr = [20, 40, 60, 80, 100] 
key = 80 
max_size = len(arr)
result = recursive_binary(arr, 0, max_size - 1, key)  
if result != -1:  
   print("The element", key, "is present at index", (result), "in the position", (result + 1)) 
else:  
   print("The element is not present in the array") 

Output

上述程序的输出如下:

The element 80  is found at the index 3 and in the position 4

Example

In this example, we are going to learn about the process of searching an element in an array using Binary search in iterative approach.

def iterative_binary(arr, last, key_element):
   first = 0
   mid = 0
   while first <= last: 

      mid = (first + last) // 2 
      if arr[mid] < key_element:
         first = mid + 1 

      elif arr[mid] > key_element: 
         last = mid - 1 

      else: 
         return mid 

   return -1 

arr = [20, 40, 60, 80, 100] 
key = 80 
max_size = len(arr)

result = iterative_binary(arr, max_size - 1, key)  

if result != -1:  
   print("The element", key, "is present at index", (result), "in the position", (result + 1)) 
else:  
   print("The element is not present in the array")

Output

上述程序的输出如下:

The element 80  is found at the index 3 and in the position 4

这是二分搜索算法的工作原理。根据时间复杂度的概念,我们可以肯定二分搜索算法比线性搜索算法更高效,时间复杂度在其中起着重要的作用。通过使用这种类型的算法,可以搜索数组中的元素。尽管用于解决问题的过程不同,但结果不会波动。这是使用多种算法检查输出一致性的一个优点。

위 내용은 배열의 요소를 검색하는 Python 프로그램의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명
이 기사는 tutorialspoint에서 복제됩니다. 침해가 있는 경우 admin@php.cn으로 문의하시기 바랍니다. 삭제
파이썬 : 게임, Guis 등파이썬 : 게임, Guis 등Apr 13, 2025 am 12:14 AM

Python은 게임 및 GUI 개발에서 탁월합니다. 1) 게임 개발은 Pygame을 사용하여 드로잉, 오디오 및 기타 기능을 제공하며 2D 게임을 만드는 데 적합합니다. 2) GUI 개발은 Tkinter 또는 PYQT를 선택할 수 있습니다. Tkinter는 간단하고 사용하기 쉽고 PYQT는 풍부한 기능을 가지고 있으며 전문 개발에 적합합니다.

Python vs. C : 응용 및 사용 사례가 비교되었습니다Python vs. C : 응용 및 사용 사례가 비교되었습니다Apr 12, 2025 am 12:01 AM

Python은 데이터 과학, 웹 개발 및 자동화 작업에 적합한 반면 C는 시스템 프로그래밍, 게임 개발 및 임베디드 시스템에 적합합니다. Python은 단순성과 강력한 생태계로 유명하며 C는 고성능 및 기본 제어 기능으로 유명합니다.

2 시간의 파이썬 계획 : 현실적인 접근2 시간의 파이썬 계획 : 현실적인 접근Apr 11, 2025 am 12:04 AM

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

파이썬 : 기본 응용 프로그램 탐색파이썬 : 기본 응용 프로그램 탐색Apr 10, 2025 am 09:41 AM

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

2 시간 안에 얼마나 많은 파이썬을 배울 수 있습니까?2 시간 안에 얼마나 많은 파이썬을 배울 수 있습니까?Apr 09, 2025 pm 04:33 PM

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

10 시간 이내에 프로젝트 및 문제 중심 방법에서 컴퓨터 초보자 프로그래밍 기본 사항을 가르치는 방법?10 시간 이내에 프로젝트 및 문제 중심 방법에서 컴퓨터 초보자 프로그래밍 기본 사항을 가르치는 방법?Apr 02, 2025 am 07:18 AM

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

중간 독서를 위해 Fiddler를 사용할 때 브라우저에서 감지되는 것을 피하는 방법은 무엇입니까?중간 독서를 위해 Fiddler를 사용할 때 브라우저에서 감지되는 것을 피하는 방법은 무엇입니까?Apr 02, 2025 am 07:15 AM

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

Python 3.6에 피클 파일을로드 할 때 '__builtin__'모듈을 찾을 수없는 경우 어떻게해야합니까?Python 3.6에 피클 파일을로드 할 때 '__builtin__'모듈을 찾을 수없는 경우 어떻게해야합니까?Apr 02, 2025 am 07:12 AM

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

See all articles

핫 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 옷 제거제

AI Hentai Generator

AI Hentai Generator

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

인기 기사

R.E.P.O. 에너지 결정과 그들이하는 일 (노란색 크리스탈)
3 몇 주 전By尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. 최고의 그래픽 설정
3 몇 주 전By尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. 아무도들을 수없는 경우 오디오를 수정하는 방법
3 몇 주 전By尊渡假赌尊渡假赌尊渡假赌
WWE 2K25 : Myrise에서 모든 것을 잠금 해제하는 방법
4 몇 주 전By尊渡假赌尊渡假赌尊渡假赌

뜨거운 도구

맨티스BT

맨티스BT

Mantis는 제품 결함 추적을 돕기 위해 설계된 배포하기 쉬운 웹 기반 결함 추적 도구입니다. PHP, MySQL 및 웹 서버가 필요합니다. 데모 및 호스팅 서비스를 확인해 보세요.

MinGW - Windows용 미니멀리스트 GNU

MinGW - Windows용 미니멀리스트 GNU

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

ZendStudio 13.5.1 맥

ZendStudio 13.5.1 맥

강력한 PHP 통합 개발 환경

에디트플러스 중국어 크랙 버전

에디트플러스 중국어 크랙 버전

작은 크기, 구문 강조, 코드 프롬프트 기능을 지원하지 않음

스튜디오 13.0.1 보내기

스튜디오 13.0.1 보내기

강력한 PHP 통합 개발 환경