Java java지도 시간 Java 세트의 전원 세트를 효율적으로 생성하는 방법은 무엇입니까?

Java 세트의 전원 세트를 효율적으로 생성하는 방법은 무엇입니까?

Dec 02, 2024 pm 06:48 PM

How to Efficiently Generate the Power Set of a Java Set?

Java에서 최적의 복잡성으로 집합의 Powerset 얻기

집합의 Powerset은 해당 집합의 모든 하위 집합의 모음입니다. n개의 요소가 있는 집합의 경우 powerset에는 2^n개의 하위 집합이 포함됩니다.

Java 집합을 고려해 보겠습니다.

1

2

3

4

Set<Integer> mySet = new HashSet<>();

mySet.add(1);

mySet.add(2);

mySet.add(3);

로그인 후 복사

getPowerset이라는 함수를 작성하여 다음의 powerset을 생성하려고 합니다. 이 세트. 이 작업의 이상적인 복잡성은 O(2^n)입니다.

Java의 제네릭과 집합을 사용하여 가능한 구현 중 하나는 다음과 같습니다.

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

public static <T> Set<Set<T>> getPowerset(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 : getPowerset(rest)) {

        Set<T> newSet = new HashSet<>();

        newSet.add(head);

        newSet.addAll(set);

        sets.add(newSet);

        sets.add(set);

    }

 

    return sets;

}

로그인 후 복사

이 재귀 솔루션은 집합의 요소를 반복합니다. 이를 각 하위 집합에 추가하고 새 하위 집합을 생성합니다. 나머지 요소의 전력 세트를 일관되게 유지합니다.

예제 입력을 사용한 간단한 테스트로 예상한 결과를 얻을 수 있습니다.

1

2

3

for (Set<Integer> s : getPowerset(mySet)) {

    System.out.println(s);

}

로그인 후 복사

출력:

1

2

3

4

5

6

7

8

[]

[1]

[2]

[1, 2]

[3]

[1, 3]

[2, 3]

[1, 2, 3]

로그인 후 복사

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

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

뜨거운 기사 태그

메모장++7.3.1

메모장++7.3.1

사용하기 쉬운 무료 코드 편집기

SublimeText3 중국어 버전

SublimeText3 중국어 버전

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

스튜디오 13.0.1 보내기

스튜디오 13.0.1 보내기

강력한 PHP 통합 개발 환경

드림위버 CS6

드림위버 CS6

시각적 웹 개발 도구

SublimeText3 Mac 버전

SublimeText3 Mac 버전

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

2025 년 상위 4 개의 JavaScript 프레임 워크 : React, Angular, Vue, Svelte 2025 년 상위 4 개의 JavaScript 프레임 워크 : React, Angular, Vue, Svelte Mar 07, 2025 pm 06:09 PM

2025 년 상위 4 개의 JavaScript 프레임 워크 : React, Angular, Vue, Svelte

Java의 클래스로드 메커니즘은 다른 클래스 로더 및 대표 모델을 포함하여 어떻게 작동합니까? Java의 클래스로드 메커니즘은 다른 클래스 로더 및 대표 모델을 포함하여 어떻게 작동합니까? Mar 17, 2025 pm 05:35 PM

Java의 클래스로드 메커니즘은 다른 클래스 로더 및 대표 모델을 포함하여 어떻게 작동합니까?

캐싱 및 게으른 하중과 같은 고급 기능을 사용하여 객체 관계 매핑에 JPA (Java Persistence API)를 어떻게 사용하려면 어떻게해야합니까? 캐싱 및 게으른 하중과 같은 고급 기능을 사용하여 객체 관계 매핑에 JPA (Java Persistence API)를 어떻게 사용하려면 어떻게해야합니까? Mar 17, 2025 pm 05:43 PM

캐싱 및 게으른 하중과 같은 고급 기능을 사용하여 객체 관계 매핑에 JPA (Java Persistence API)를 어떻게 사용하려면 어떻게해야합니까?

고급 Java 프로젝트 관리, 구축 자동화 및 종속성 해상도에 Maven 또는 Gradle을 어떻게 사용합니까? 고급 Java 프로젝트 관리, 구축 자동화 및 종속성 해상도에 Maven 또는 Gradle을 어떻게 사용합니까? Mar 17, 2025 pm 05:46 PM

고급 Java 프로젝트 관리, 구축 자동화 및 종속성 해상도에 Maven 또는 Gradle을 어떻게 사용합니까?

빙산 : 데이터 호수 테이블의 미래 빙산 : 데이터 호수 테이블의 미래 Mar 07, 2025 pm 06:31 PM

빙산 : 데이터 호수 테이블의 미래

카페인 또는 구아바 캐시와 같은 라이브러리를 사용하여 자바 애플리케이션에서 다단계 캐싱을 구현하려면 어떻게해야합니까? 카페인 또는 구아바 캐시와 같은 라이브러리를 사용하여 자바 애플리케이션에서 다단계 캐싱을 구현하려면 어떻게해야합니까? Mar 17, 2025 pm 05:44 PM

카페인 또는 구아바 캐시와 같은 라이브러리를 사용하여 자바 애플리케이션에서 다단계 캐싱을 구현하려면 어떻게해야합니까?

Node.js 20 : 주요 성능 향상 및 새로운 기능 Node.js 20 : 주요 성능 향상 및 새로운 기능 Mar 07, 2025 pm 06:12 PM

Node.js 20 : 주요 성능 향상 및 새로운 기능

Spring Boot Snakeyaml 2.0 CVE-2022-1471 문제 고정 Spring Boot Snakeyaml 2.0 CVE-2022-1471 문제 고정 Mar 07, 2025 pm 05:52 PM

Spring Boot Snakeyaml 2.0 CVE-2022-1471 문제 고정

See all articles