Java java지도 시간 Java에서 두 개의 정렬된 배열의 중앙값 찾기

Java에서 두 개의 정렬된 배열의 중앙값 찾기

Jul 22, 2024 pm 05:46 PM

Finding the Median of Two Sorted Arrays in Java

JAVA 튜토리얼
자바 파일

소개

두 개의 정렬된 배열의 중앙값을 찾는 문제는 전형적인 코딩 인터뷰 질문입니다. 문제는 O(log(min(m, n)))의 시간 복잡도로 중앙값을 효율적으로 찾는 것입니다. 여기서 m과 n은 두 배열의 크기입니다. 이 기사에서는 이러한 효율성을 달성하기 위해 이진 검색을 사용하는 Java 솔루션을 살펴보겠습니다.

문제 설명

두 개의 정렬된 배열 nums1과 nums2가 주어지면 두 개의 정렬된 배열의 중앙값을 찾습니다. 전체 런타임 복잡도는 O(log(min(m, n)))이어야 합니다. 여기서 m과 n은 두 배열의 크기입니다.

접근하다

이 문제를 해결하기 위해 우리는 두 배열 중 더 작은 배열에 대해 이진 검색 접근 방식을 사용합니다. 목표는 왼쪽 절반에 오른쪽 절반의 요소보다 작거나 같은 모든 요소가 포함되도록 두 배열을 분할하는 것입니다. 단계별 설명은 다음과 같습니다.

  1. nums1이 더 작은 배열인지 확인하세요: 더 쉬운 이진 검색을 위해 nums1이 더 작은 배열인지 확인하세요.
  2. 이진 검색 수행: nums1에서 이진 검색을 사용하여 올바른 파티션을 찾습니다.
  3. 분할: 왼쪽에는 낮은 요소가 포함되고 오른쪽에는 높은 요소가 포함되도록 두 배열을 분할합니다.
  4. 중앙값 계산: 파티션을 기준으로 중앙값을 계산합니다.

해결책

다음은 솔루션의 자세한 Java 구현입니다.

public class MedianOfTwoSortedArrays {
    public double findMedianSortedArrays(int[] nums1, int[] nums2) {
        // Ensure nums1 is the smaller array
        if (nums1.length > nums2.length) {
            int[] temp = nums1;
            nums1 = nums2;
            nums2 = temp;
        }

        int x = nums1.length;
        int y = nums2.length;
        int low = 0, high = x;

        while (low <= high) {
            int partitionX = (low + high) / 2;
            int partitionY = (x + y + 1) / 2 - partitionX;

            // Edge cases
            int maxX = (partitionX == 0) ? Integer.MIN_VALUE : nums1[partitionX - 1];
            int minX = (partitionX == x) ? Integer.MAX_VALUE : nums1[partitionX];
            int maxY = (partitionY == 0) ? Integer.MIN_VALUE : nums2[partitionY - 1];
            int minY = (partitionY == y) ? Integer.MAX_VALUE : nums2[partitionY];

            if (maxX <= minY && maxY <= minX) {
                // Correct partition
                if ((x + y) % 2 == 0) {
                    return (Math.max(maxX, maxY) + Math.min(minX, minY)) / 2.0;
                } else {
                    return Math.max(maxX, maxY);
                }
            } else if (maxX > minY) {
                high = partitionX - 1;
            } else {
                low = partitionX + 1;
            }
        }

        throw new IllegalArgumentException("Input arrays are not sorted");
    }

    public static void main(String[] args) {
        MedianOfTwoSortedArrays solution = new MedianOfTwoSortedArrays();

        int[] nums1 = {1, 3};
        int[] nums2 = {2};
        System.out.println("Median: " + solution.findMedianSortedArrays(nums1, nums2)); // Output: 2.0

        int[] nums1_2 = {1, 2};
        int[] nums2_2 = {3, 4};
        System.out.println("Median: " + solution.findMedianSortedArrays(nums1_2, nums2_2)); // Output: 2.5
    }
}
로그인 후 복사

설명

  1. 초기화: nums1이 더 작은 배열인지 확인하세요.
  2. 이진 검색: nums1에서 이진 검색을 수행하여 올바른 파티션을 찾습니다.
  3. 파티션 및 중앙값 계산: 왼쪽 요소의 최대값과 오른쪽 요소의 최소값을 계산하여 중앙값을 찾습니다.

결론

이 이진 검색 접근 방식은 두 개의 정렬된 배열의 중앙값을 찾는 효율적인 솔루션을 제공합니다. 이 솔루션은 더 작은 배열에서 이진 검색을 활용하여 O(log(min(m, n)))의 시간 복잡도를 달성하므로 대규모 입력 배열에 적합합니다.

위 내용은 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의 클래스로드 메커니즘은 다른 클래스 로더 및 대표 모델을 포함하여 어떻게 작동합니까?

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

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

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

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

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

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

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

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

Java에서 기능 프로그래밍 기술을 어떻게 구현할 수 있습니까? Java에서 기능 프로그래밍 기술을 어떻게 구현할 수 있습니까? Mar 11, 2025 pm 05:51 PM

Java에서 기능 프로그래밍 기술을 어떻게 구현할 수 있습니까?

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