Java 세트의 전원 세트를 효율적으로 생성하는 방법은 무엇입니까?
Dec 02, 2024 pm 06:48 PMJava에서 최적의 복잡성으로 집합의 Powerset 얻기
집합의 Powerset은 해당 집합의 모든 하위 집합의 모음입니다. n개의 요소가 있는 집합의 경우 powerset에는 2^n개의 하위 집합이 포함됩니다.
Java 집합을 고려해 보겠습니다.
1 2 3 4 |
|
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 |
|
이 재귀 솔루션은 집합의 요소를 반복합니다. 이를 각 하위 집합에 추가하고 새 하위 집합을 생성합니다. 나머지 요소의 전력 세트를 일관되게 유지합니다.
예제 입력을 사용한 간단한 테스트로 예상한 결과를 얻을 수 있습니다.
1 2 3 |
|
출력:
1 2 3 4 5 6 7 8 |
|
위 내용은 Java 세트의 전원 세트를 효율적으로 생성하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

인기 기사

인기 기사

뜨거운 기사 태그

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

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

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

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

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

뜨거운 주제











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

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

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

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

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

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