> 백엔드 개발 > 파이썬 튜토리얼 > 정렬되지 않은 Python 목록에서 요소 빈도를 효율적으로 계산하는 방법은 무엇입니까?

정렬되지 않은 Python 목록에서 요소 빈도를 효율적으로 계산하는 방법은 무엇입니까?

Linda Hamilton
풀어 주다: 2025-01-03 17:28:40
원래의
680명이 탐색했습니다.

How to Efficiently Count Element Frequencies in an Unordered Python List?

순서가 없는 목록에서 요소의 빈도 구하기

a = [5, 1, 2, 2, 4, 3, 1, 2, 3, 1, 1, 5, 2]. 목표는 목록 내 각 고유 값의 빈도를 결정하는 것입니다. 원하는 출력은 b = [4, 4, 2, 1, 2]와 유사하며, 이는 값 1이 4번 나타나고, 2가 4번 나타나고, 3이 2번 나타나고, 4가 1번 나타나고, 5가 2번 나타남을 나타냅니다.

Python에서 이 작업을 위한 편리한 솔루션은 collections.Counter 클래스를 활용하는 것입니다. Python 2.7 이상에서 이 클래스는 순서가 지정되지 않은 컬렉션에서 요소의 발생 횟수를 계산하는 프로세스를 단순화합니다.

import collections

a = [5, 1, 2, 2, 4, 3, 1, 2, 3, 1, 1, 5, 2]
counter = collections.Counter(a)
로그인 후 복사

collections.Counter 개체인 counter는 목록에 있는 각 고유 값의 개수를 보유합니다. . 다양한 방법을 사용하여 개수에 액세스할 수 있습니다.

  • counter.values(): 각 고유 값의 개수가 포함된 목록을 반환합니다.
  • counter.keys(): 목록을 반환합니다. 목록에 고유한 값이 포함되어 있습니다.
  • counter.most_common(n): 가장 많은 n개를 포함하는 튜플 목록을 반환합니다. 자주 발생하는 값과 개수.
  • dict(counter): 고유 값인 키와 개수인 값을 사용하여 Counter 개체를 일반 사전으로 변환합니다.

개수를 얻으려면 질문에 지정된 순서대로 정렬된 순서로 키를 반복할 수 있습니다.

[counter[x] for x in sorted(counter.keys())]
로그인 후 복사

Python 2.6을 사용하는 경우 이전 버전에서는 제공된 링크에서 collections.Counter 구현을 다운로드하여 코드에서 사용할 수 있습니다.

위 내용은 정렬되지 않은 Python 목록에서 요소 빈도를 효율적으로 계산하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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