순서가 없는 목록에서 요소의 빈도 구하기
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[x] for x in sorted(counter.keys())]
Python 2.6을 사용하는 경우 이전 버전에서는 제공된 링크에서 collections.Counter 구현을 다운로드하여 코드에서 사용할 수 있습니다.
위 내용은 정렬되지 않은 Python 목록에서 요소 빈도를 효율적으로 계산하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!