>Java >java지도 시간 >Java에서 세트의 Powerset을 효율적으로 계산하는 방법은 무엇입니까?

Java에서 세트의 Powerset을 효율적으로 계산하는 방법은 무엇입니까?

Patricia Arquette
Patricia Arquette원래의
2024-11-30 04:21:15338검색

How to Efficiently Compute the Powerset of a Set in Java?

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 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.