Java에서 세트의 Powerset을 효율적으로 계산하는 방법은 무엇입니까?
Java의 집합에 대한 Powerset 계산
컴퓨터 과학에서 집합의 Powerset은 해당 집합의 가능한 모든 하위 집합의 모음을 나타냅니다. 이 기사에서는 최적의 시간 복잡도를 위해 노력하면서 Java에서 정수 집합의 파워셋을 구성하는 방법을 살펴봅니다.
문제 설명
Java에서 정의된 정수 집합이 주어졌습니다. , 우리의 목표는 powerset을 계산하는 getPowerset 함수를 만드는 것입니다. 우리는 이 함수에 대해 가능한 최고의 시간 복잡도를 달성하는 것을 목표로 합니다.
해결책
파워셋 계산의 시간 복잡도는 실제로 O(2^n)입니다. 여기서 n은 원래 세트의 크기입니다. 아래 함수는 제네릭과 집합을 활용하여 powerset 계산을 효율적으로 구현합니다.
public static <T> Set<Set<T>> powerSet(Set<T> originalSet) { Set<Set<T>> sets = new HashSet<>(); if (originalSet.isEmpty()) { sets.add(new HashSet<>()); return sets; } List<T> list = new ArrayList<>(originalSet); T head = list.get(0); Set<T> rest = new HashSet<>(list.subList(1, list.size())); for (Set<T> set : powerSet(rest)) { Set<T> newSet = new HashSet<>(); newSet.add(head); newSet.addAll(set); sets.add(newSet); sets.add(set); } return sets; }
Test
다음 코드는 예제 입력을 사용하여 함수를 보여줍니다.
Set<Integer> mySet = new HashSet<>(); mySet.add(1); mySet.add(2); mySet.add(3); for (Set<Integer> s : SetUtils.powerSet(mySet)) { System.out.println(s); }
출력
질문에 제공된 테스트 출력은 {1, 2, 3}의 거듭제곱 집합을 표시합니다.
[] [2] [3] [2, 3] [1] [1, 2] [1, 3] [1, 2, 3]
일반 및 재귀를 사용하여 getPowerset 함수를 구현하여 O의 최적 시간 복잡도를 달성합니다. (2^n) 및 Java에서 집합의 파워셋을 계산하기 위한 효율적인 솔루션입니다.
위 내용은 Java에서 세트의 Powerset을 효율적으로 계산하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

핫 AI 도구

Undresser.AI Undress
사실적인 누드 사진을 만들기 위한 AI 기반 앱

AI Clothes Remover
사진에서 옷을 제거하는 온라인 AI 도구입니다.

Undress AI Tool
무료로 이미지를 벗다

Clothoff.io
AI 옷 제거제

Video Face Swap
완전히 무료인 AI 얼굴 교환 도구를 사용하여 모든 비디오의 얼굴을 쉽게 바꾸세요!

인기 기사

뜨거운 도구

메모장++7.3.1
사용하기 쉬운 무료 코드 편집기

SublimeText3 중국어 버전
중국어 버전, 사용하기 매우 쉽습니다.

스튜디오 13.0.1 보내기
강력한 PHP 통합 개발 환경

드림위버 CS6
시각적 웹 개발 도구

SublimeText3 Mac 버전
신 수준의 코드 편집 소프트웨어(SublimeText3)

일부 애플리케이션이 제대로 작동하지 않는 회사의 보안 소프트웨어에 대한 문제 해결 및 솔루션. 많은 회사들이 내부 네트워크 보안을 보장하기 위해 보안 소프트웨어를 배포 할 것입니다. ...

많은 응용 프로그램 시나리오에서 정렬을 구현하기 위해 이름으로 이름을 변환하는 솔루션, 사용자는 그룹으로, 특히 하나로 분류해야 할 수도 있습니다.

시스템 도킹의 필드 매핑 처리 시스템 도킹을 수행 할 때 어려운 문제가 발생합니다. 시스템의 인터페이스 필드를 효과적으로 매핑하는 방법 ...

IntellijideAultimate 버전을 사용하여 봄을 시작하십시오 ...

데이터베이스 작업에 MyBatis-Plus 또는 기타 ORM 프레임 워크를 사용하는 경우 엔티티 클래스의 속성 이름을 기반으로 쿼리 조건을 구성해야합니다. 매번 수동으로 ...

Java 객체 및 배열의 변환 : 캐스트 유형 변환의 위험과 올바른 방법에 대한 심층적 인 논의 많은 Java 초보자가 객체를 배열로 변환 할 것입니다 ...

전자 상거래 플랫폼에서 SKU 및 SPU 테이블의 디자인에 대한 자세한 설명이 기사는 전자 상거래 플랫폼에서 SKU 및 SPU의 데이터베이스 설계 문제, 특히 사용자 정의 판매를 처리하는 방법에 대해 논의 할 것입니다 ...

Redis 캐싱 솔루션은 제품 순위 목록의 요구 사항을 어떻게 인식합니까? 개발 과정에서 우리는 종종 a ... 표시와 같은 순위의 요구 사항을 처리해야합니다.
