병합 정렬의 Java 구현
병합 정렬(MERGE-SORT)은 병합 작업을 기반으로 하는 효과적인 정렬 알고리즘입니다. 이 알고리즘은 분할 및 정복 방법(pide 및 Conquer)의 매우 일반적인 예입니다. 애플리케이션. 이미 정렬된 하위 시퀀스를 병합하여 완전히 정렬된 시퀀스를 얻습니다. 즉, 먼저 각 하위 시퀀스를 순서대로 만든 다음 하위 시퀀스 세그먼트를 순서대로 만듭니다. 두 개의 순서 목록이 하나의 순서 목록으로 병합되는 경우 이를 양방향 병합이라고 합니다. 병합 프로세스는 다음과 같습니다. a[i]와 b[j]의 크기를 비교하고, a[i]≤b[j]인 경우 첫 번째 순서 목록의 a[i] 요소를 r[k]에 복사하고 추가합니다. 1을 i와 k에 각각 복사하고, 그렇지 않으면 두 번째 순서 목록의 요소 b[j]를 r[k]에 복사하고 j와 k에 각각 1을 추가하는 식으로 계속 진행합니다. 하나의 순서 목록을 가져온 후 나머지 다른 순서 목록의 요소는 아래 첨자 k에서 아래 첨자 t까지 r의 셀에 복사됩니다. 우리는 병합 정렬 알고리즘을 구현하기 위해 일반적으로 재귀를 사용합니다. 먼저 정렬할 간격 [s, t]를 중간점을 기준으로 2개로 나눈 다음 왼쪽 하위 범위를 정렬한 다음 오른쪽 하위 범위를 정렬합니다. 마지막으로 왼쪽 간격과 오른쪽 간격이 순서가 지정된 간격 [s,t]로 병합됩니다.
주요 두 가지 사항:
1 두 개의 정렬된 시퀀스를 하나의 정렬된 시퀀스로 병합하는 방법
2 이 두 시퀀스를 정렬된 시퀀스로 바꾸는 방법
첫 번째 문제 해결:
주문한 두 계열을 병합하는 방법. 이는 매우 간단합니다. 두 시퀀스의 첫 번째 숫자를 비교하여 더 작은 숫자를 먼저 취한 후 해당 시퀀스의 숫자를 삭제하면 됩니다. 그런 다음 열 중 하나가 비어 있으면 다른 열의 데이터를 하나씩 꺼내십시오.
public static void merge(int[] nums, int low, int mid, int high) { int[] temp = new int[high - low + 1]; int i = low;// 左指针 int j = mid + 1;// 右指针 int k = 0; // 把较小的数先移到新数组中 while (i <p style="margin-top:0px; margin-bottom:16px; color:rgb(51,51,51); font-family:'Helvetica Neue',Helvetica,'Segoe UI',Arial,freesans,sans-serif,'Apple Color Emoji','Segoe UI Emoji','Segoe UI Symbol'; font-size:14px; line-height:22.4px">두 번째 질문: 그룹 A와 B는 두 그룹으로 나눌 수 있습니다. 비유하자면, 분리된 그룹에 하나의 데이터만 있는 경우 그룹이 순서에 도달한 것으로 간주하고 인접한 두 그룹을 병합할 수 있습니다. 이런 방식으로 병합 정렬은 먼저 배열을 재귀적으로 분해한 다음 배열을 병합하여 완료됩니다. </p><pre style="font-size:11.9px; line-height:1.45; font-family:Consolas,'Liberation Mono',Menlo,Courier,monospace; word-wrap:normal; margin-top:0px; margin-bottom:16px; padding:16px; overflow:auto; color:rgb(51,51,51); background-color:rgb(247,247,247)">public static int[] sort(int[] nums, int low, int high) { int mid = (low + high) / 2; if (low <p style="margin-top:0px; margin-bottom:16px; color:rgb(51,51,51); font-family:'Helvetica Neue',Helvetica,'Segoe UI',Arial,freesans,sans-serif,'Apple Color Emoji','Segoe UI Emoji','Segoe UI Symbol'; font-size:14px; line-height:22.4px">전체 코드: </p><pre style="font-size:11.9px; line-height:1.45; font-family:Consolas,'Liberation Mono',Menlo,Courier,monospace; word-wrap:normal; margin-top:0px; padding:16px; overflow:auto; color:rgb(51,51,51); margin-bottom:0px!important; background-color:rgb(247,247,247)">package algorithm;import java.util.Arrays;public class MergeSort { public static int[] sort(int[] nums, int low, int high) { int mid = (low + high) / 2; if (low <p> </p>
위 내용은 병합 정렬이란 Java의 병합 정렬에 대한 자세한 설명입니다.의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

이 기사에서는 Java 프로젝트 관리, 구축 자동화 및 종속성 해상도에 Maven 및 Gradle을 사용하여 접근 방식과 최적화 전략을 비교합니다.

이 기사에서는 Maven 및 Gradle과 같은 도구를 사용하여 적절한 버전 및 종속성 관리로 사용자 정의 Java 라이브러리 (JAR Files)를 작성하고 사용하는 것에 대해 설명합니다.

이 기사는 카페인 및 구아바 캐시를 사용하여 자바에서 다단계 캐싱을 구현하여 응용 프로그램 성능을 향상시키는 것에 대해 설명합니다. 구성 및 퇴거 정책 관리 Best Pra와 함께 설정, 통합 및 성능 이점을 다룹니다.

이 기사는 캐싱 및 게으른 하중과 같은 고급 기능을 사용하여 객체 관계 매핑에 JPA를 사용하는 것에 대해 설명합니다. 잠재적 인 함정을 강조하면서 성능을 최적화하기위한 설정, 엔티티 매핑 및 모범 사례를 다룹니다. [159 문자]

Java의 클래스 로딩에는 부트 스트랩, 확장 및 응용 프로그램 클래스 로더가있는 계층 적 시스템을 사용하여 클래스로드, 링크 및 초기화 클래스가 포함됩니다. 학부모 위임 모델은 핵심 클래스가 먼저로드되어 사용자 정의 클래스 LOA에 영향을 미치도록합니다.


핫 AI 도구

Undresser.AI Undress
사실적인 누드 사진을 만들기 위한 AI 기반 앱

AI Clothes Remover
사진에서 옷을 제거하는 온라인 AI 도구입니다.

Undress AI Tool
무료로 이미지를 벗다

Clothoff.io
AI 옷 제거제

AI Hentai Generator
AI Hentai를 무료로 생성하십시오.

인기 기사

뜨거운 도구

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

SecList
SecLists는 최고의 보안 테스터의 동반자입니다. 보안 평가 시 자주 사용되는 다양한 유형의 목록을 한 곳에 모아 놓은 것입니다. SecLists는 보안 테스터에게 필요할 수 있는 모든 목록을 편리하게 제공하여 보안 테스트를 더욱 효율적이고 생산적으로 만드는 데 도움이 됩니다. 목록 유형에는 사용자 이름, 비밀번호, URL, 퍼징 페이로드, 민감한 데이터 패턴, 웹 셸 등이 포함됩니다. 테스터는 이 저장소를 새로운 테스트 시스템으로 간단히 가져올 수 있으며 필요한 모든 유형의 목록에 액세스할 수 있습니다.

PhpStorm 맥 버전
최신(2018.2.1) 전문 PHP 통합 개발 도구

ZendStudio 13.5.1 맥
강력한 PHP 통합 개발 환경

SublimeText3 Linux 새 버전
SublimeText3 Linux 최신 버전
