>Java >java지도 시간 >Java에서 집합의 Powerset을 효율적으로 생성하는 방법은 무엇입니까?

Java에서 집합의 Powerset을 효율적으로 생성하는 방법은 무엇입니까?

Barbara Streisand
Barbara Streisand원래의
2024-11-30 22:07:12919검색

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

Java에서 Powerset 찾기: 효율적인 접근 방식

집합의 Powerset은 원래 집합의 가능한 모든 하위 집합을 포함합니다. 크기 n 집합의 경우 powerset에는 2^n 요소가 포함됩니다. Java에서는 효율적인 알고리즘을 사용하여 Powerset 생성을 처리하는 것이 일반적입니다.

예를 고려하세요.

Set mySet = new HashSet<>();
mySet.add(1);
mySet.add(2);
mySet.add(3);
Set> ; powerSet = getPowerset(mySet);

이 설정을 사용하여 작업은 최적의 시간 복잡도로 mySet의 powerset을 생성하는 getPowerset 함수를 설계하는 것입니다.

최적 시간 복잡도: O (2^n)

언급했듯이 파워셋에는 2^n 요소가 포함되어 있습니다. 따라서 이러한 모든 요소를 ​​생성하려면 본질적으로 O(2^n) 시간 복잡성이 필요합니다.

구현

다음 코드는 일반적이고 효율적인 구현을 제공합니다.

공개 정적 설정> powerSet(Set 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;

}

앞서 제공된 예 활용:

세트<정수> mySet = new HashSet<>();
mySet.add(1);
mySet.add(2);
mySet.add(3);
for (Set s : 파워셋(마이셋)) {

System.out.println(s);

}

출력은 다음과 같습니다.

{}
{1}
{2}
{1, 2}
{3}
{1, 3}
{2, 3}
{1, 2, 3}

이는 O(2^n) 시간 복잡도로 지정된 집합의 거듭제곱 집합을 생성하는 방법을 보여줍니다.

위 내용은 Java에서 집합의 Powerset을 효율적으로 생성하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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