> 백엔드 개발 > 파이썬 튜토리얼 > Python에서 선택 정렬 알고리즘을 작성하는 방법은 무엇입니까?

Python에서 선택 정렬 알고리즘을 작성하는 방법은 무엇입니까?

WBOY
풀어 주다: 2023-09-19 08:16:48
원래의
780명이 탐색했습니다.

Python에서 선택 정렬 알고리즘을 작성하는 방법은 무엇입니까?

Python에서 선택 정렬 알고리즘을 작성하는 방법은 무엇입니까?

선택 정렬은 간단하고 직관적인 정렬 알고리즘의 기본 아이디어는 가장 작은 요소를 찾아 정렬된 부분의 끝에 넣은 다음 정렬되지 않은 부분에서 가장 작은 요소를 계속 찾아 전체가 될 때까지 이 과정을 반복하는 것입니다. 배열이 정렬되었습니다.

이제 Python에서 선택 정렬 알고리즘을 작성하는 방법을 자세히 소개하겠습니다.

먼저 선택 정렬을 구현하기 위해 select_sort 함수를 정의합니다. 이 함수는 배열을 매개변수로 받아 원래 배열을 정렬합니다. 함수 내부에는 두 개의 중첩 루프가 사용되며, 외부 루프는 배열을 순회하는 데 사용되고, 내부 루프는 정렬되지 않은 부분에서 가장 작은 요소의 인덱스를 찾는 데 사용됩니다.

코드는 다음과 같습니다.

def select_sort(arr):
    n = len(arr)
    for i in range(n-1):
        min_index = i
        for j in range(i+1, n):
            if arr[j] < arr[min_index]:
                min_index = j
        arr[i], arr[min_index] = arr[min_index], arr[i]
로그인 후 복사

다음으로 선택 정렬 알고리즘의 효과를 테스트할 수 있습니다. 예를 들어 정수 배열을 정렬하면

arr = [64, 25, 12, 22, 11]
select_sort(arr)
print("排序后的数组:")
for i in range(len(arr)):
    print("%d" % arr[i])
로그인 후 복사

실행 결과는 다음과 같습니다.

排序后的数组:
11
12
22
25
64
로그인 후 복사

선택 정렬 알고리즘이 입력 배열을 오름차순으로 성공적으로 정렬한 것을 확인할 수 있습니다.

선택 정렬 알고리즘의 시간 복잡도는 입력 데이터에 관계없이 O(n^2)입니다. 따라서 실제 응용에서 선택 정렬 알고리즘은 효율성이 낮고 대규모 데이터를 처리하는 정렬 작업에는 적합하지 않습니다.

요약하자면, 이 글에서는 Python에서 선택 정렬 알고리즘을 작성하는 방법을 소개하고 구체적인 코드 예제를 제공합니다. 독자들이 이 글을 읽으면서 선택 정렬 알고리즘의 기본 원리와 구현 방법을 익히고, 실무 문제에 유연하게 적용할 수 있기를 바랍니다.

위 내용은 Python에서 선택 정렬 알고리즘을 작성하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

원천:php.cn
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿