zoukankan      html  css  js  c++  java
  • java排序算法-归并排序

    public class MergeSort {
    
    	private static void mergeSortTest() {
    		int[] in = { 2, 5, 3, 8, 6, 7, 1, 4, 0, 9 };
    		Utils.printArray("归并排序前:",in);
    		int a[] = mergeSort(in);
    		Utils.printArray("归并排序后:",a);
    	}
    
    	private static int[] mergeSort(int[] arr) {
    		if (arr.length == 1) {
    			return arr;
    		} else {
    			int[] arrL = new int[arr.length / 2];
    			int[] arrR = new int[arr.length - arr.length / 2];
    			int mid = arr.length / 2;
    			for (int i = 0; i < mid; i++) {
    				arrL[i] = arr[i];
    			}
    			for (int i = mid, j = 0; i < arr.length; i++, j++) {
    				arrR[j] = arr[i];
    			}
    			int[] sortedArrL = mergeSort(arrL);
    			int[] sortedArrR = mergeSort(arrR);
    			int[] resultArr = mergeTwoArr(sortedArrL, sortedArrR);
    			return resultArr;
    		}
    	}
    
    	private static int[] mergeTwoArr(int[] arrL, int[] arrR) {
    		int i = 0, j = 0;
    		int[] arrTmp = new int[arrL.length + arrR.length];
    		int foot = 0;
    		while (i < arrL.length && j < arrR.length) {
    			if (arrL[i] <= arrR[j]) {
    				arrTmp[foot++] = arrL[i++];
    			} else {
    				arrTmp[foot++] = arrR[j++];
    			}
    		}
    		if (i == arrL.length) {
    			while (j < arrR.length) {
    				arrTmp[foot++] = arrR[j++];
    			}
    		} else {
    			while (i < arrL.length) {
    				arrTmp[foot++] = arrL[i++];
    			}
    		}
    		return arrTmp;
    	}
    	
    	public static void main(String[] args) {
    		mergeSortTest();
    	}
    }
    

      

  • 相关阅读:
    下载安装Git,学习笔记
    php面试相关整理
    2.5 DQL 分组查询
    2.4 DQL 常见函数
    2.3 DQL 排序查询
    2.2 DQL 条件查询
    2.1 DQL 基础查询
    1.2 MySQL的介绍
    1.1 数据库的相关概念
    2019年JavaEE学习线路
  • 原文地址:https://www.cnblogs.com/zhaofeng555/p/3594875.html
Copyright © 2011-2022 走看看