> Java > Java시작하기 > Java에서 삽입 정렬을 구현한 후 추가로 최적화하는 방법

Java에서 삽입 정렬을 구현한 후 추가로 최적화하는 방법

王林
풀어 주다: 2020-12-29 10:13:51
앞으로
2146명이 탐색했습니다.

Java에서 삽입 정렬을 구현한 후 추가로 최적화하는 방법

학습 동영상 공유: java 동영상 튜토리얼

일반 삽입: 배열의 두 번째 요소에서 작동하고 이전 요소가 그보다 큰 것으로 확인되면 스왑 작업을 수행합니다.

static int[] insertSort(int[] array){
        int len = array.length;
        for (int begin = 1; begin < len; begin++){
            int cur = begin;
            while (cur > 0 && array[cur] < array[cur-1]){
                int tmp = array[cur];
                array[cur] = array[cur-1];
                array[cur-1] = tmp;
                cur--;
            }
        }
        return array;
    }
로그인 후 복사

최적화의 첫 번째 단계: 배열의 두 번째 요소에서 작동합니다. 이전 요소가 그보다 큰 것으로 확인되면 cur가 가리키는 요소가 다음보다 크거나 같을 때까지 이전 요소를 뒤로 이동합니다. 이전 요소. 이때 cur가 가리키는 위치가 삽입할 요소가 삽입될 위치이다.

    static int[] insertSort2(int[] array){
        int len = array.length;
        for (int begin = 1; begin < len; begin++){
            int cur = begin;
            int tmp = array[cur];
            while (cur > 0 && array[cur] < array[cur-1]){
                array[cur] = array[cur-1];
                cur--;
            }
            array[cur] = tmp;
        }
        return array;
    }
로그인 후 복사

2단계 최적화

세 번째 알고리즘은 기본적으로 두 번째 알고리즘과 동일합니다. 그러나 세 번째 알고리즘은 삽입할 위치를 찾고 요소를 이동합니다. 이진 검색은 비교 횟수, 즉 cmp 함수 호출을 줄이고 swap 함수 호출도 줄입니다. 현재 요소를 삽입해야 할 위치를 찾아 이동하는 것이 더 빠르므로 효율성이 향상됩니다.

static int[] insertSort3(int[] array){
        int len = array.length;

        for (int begin = 1; begin < len; begin++){
            int v = array[begin];
            int insertIndex = search(array,begin);
            // 将 [insertIndex, begin) 范围内的元素往右边挪动一个单位
            for (int i = begin; i > insertIndex; i--){
                array[i] = array[i-1];
            }
            array[insertIndex] = v;
        }
        return array;
    }
    static int search(int[] array, int index){
        int begin = 0;
        int end = index;
        while(begin < end){
            int mid = (begin+end) >> 1;
            if (array[index] < array[mid]){
                end = mid;
            }else{
                begin = mid+1;
            }
        }
        return begin;
    }
로그인 후 복사

이진 검색을 사용한 후에는 비교 횟수만 줄어들지만 삽입 정렬의 평균 시간 복잡도는 여전히 O(n^2)

이동 작업 분리 효과:

    package com.mj.sort.cmp;import com.mj.sort.Sort;public class InsertionSort3<T extends Comparable<T>> extends Sort<T> {

	//	protected void sort() {//		for (int begin = 1; begin < array.length; begin++) {//			T v = array[begin];//			int insertIndex = search(begin);//			// 将 [insertIndex, begin) 范围内的元素往右边挪动一个单位			for (int i = begin - 1; i >= insertIndex; i--) {							}//			for (int i = begin; i > insertIndex; i--) {//				array[i] = array[i - 1];//			}//			array[insertIndex] = v;//		}//	}
	
	@Override
	protected void sort() {
		for (int begin = 1; begin < array.length; begin++) {
			insert(begin, search(begin));	//元素索引给你,你告诉这个位置的元素往哪插
		} 
	}
	
	/**
	 * 将source位置的元素插入到dest位置
	 * @param source
	 * @param dest
	 */
	private void insert(int source, int dest) {
		T v = array[source];
		for (int i = source; i > dest; i--) {
			array[i] = array[i - 1];
		}
		array[dest] = v;
	}
	
	/**
	 * 利用二分搜索找到 index 位置元素的待插入位置
	 * 已经排好序数组的区间范围是 [0, index)
	 * @param index
	 * @return
	 */
	private int search(int index) {
		int begin = 0;
		int end = index;
		while (begin < end) {
			int mid = (begin + end) >> 1;
			if (cmp(array[index], array[mid]) < 0) {
				end = mid;
			} else {
				begin = mid + 1;
			}
		}
		return begin;
	}}
로그인 후 복사

관련 권장 사항: java 입문 튜토리얼

위 내용은 Java에서 삽입 정렬을 구현한 후 추가로 최적화하는 방법의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

관련 라벨:
원천:csdn.net
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿