> 백엔드 개발 > 파이썬 튜토리얼 > 이중 정렬 없이 효율적으로 Python/NumPy에서 배열 항목의 순위를 매기는 방법은 무엇입니까?

이중 정렬 없이 효율적으로 Python/NumPy에서 배열 항목의 순위를 매기는 방법은 무엇입니까?

Susan Sarandon
풀어 주다: 2024-10-28 21:29:30
원래의
910명이 탐색했습니다.

How to Rank Array Items in Python/NumPy Efficiently Without Double Sorting?

이중 정렬 없이 Python/NumPy에서 더 빠른 배열 항목 순위 지정

데이터 분석 및 기계 학습에서는 항목의 순위를 매기는 것이 종종 필요합니다. 값을 기준으로 배열합니다. 순위를 매기기 위해 배열을 이중 정렬하는 데는 시간이 많이 걸릴 수 있습니다.

초기 접근 방식

일반적인 방법은 다음과 같습니다.

<code class="python">import numpy as np

# Sample array
array = np.array([4, 2, 7, 1])

# Temporary array for sorting
temp = array.argsort()

# Rank computation
ranks = np.arange(len(array))[temp.argsort()]</code>
로그인 후 복사

이 접근 방식은 다음과 같습니다. 두 가지 정렬 작업이 포함되어 복잡성이 증가합니다.

최적화된 솔루션

이중 정렬을 피하기 위해 NumPy의 argsort() 함수를 두 번 활용할 수 있습니다.

<code class="python">array = np.array([4, 2, 7, 1])

# First argsort to obtain element order
order = array.argsort()

# Second argsort to obtain ranking
ranks = order.argsort()</code>
로그인 후 복사

설명

먼저 argsort()를 사용하여 배열 요소의 순서를 구합니다. 그런 다음 결과 순서에 다시 argsort()를 적용하여 순위를 결정합니다.

결론

이 최적화 기술은 다음과 같이 배열 항목 순위 지정 속도를 크게 향상시킵니다. 불필요한 정렬을 피합니다. 고차원 배열의 경우 argsort의 축 인수를 사용하여 정렬할 축을 지정하세요.

위 내용은 이중 정렬 없이 효율적으로 Python/NumPy에서 배열 항목의 순위를 매기는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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