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

    public class MergeSort {
    
        public static void main(String[] args) {
    
            int[] A = { 1, 4, 3, 2, 5 };
            mergeSort(A, 5);
            for (int i = 0; i < A.length; i++) {
                System.out.println(A[i]);
                
            }
        }
    
        public static int[] mergeSort(int[] A, int n) {
            // write code here
            sort(A, 0, n - 1);
            return A;
        }
    
        public static void sort(int[] A, int left, int right) {
            if (left < right) {
                int mid = (left + right) / 2;
                sort(A, left, mid);
                sort(A, mid + 1, right);
                merge(A, left, mid, right);
            }
        }
    
        public static void merge(int[] A, int left, int mid, int right) {
            // 临时数组
    
            int n = right - left + 1;
            int[] tmpArr = new int[n];
            int l = left;
            int r = mid + 1;
            int t = 0;// 临时数组下标元素
    
            // 比较两子序列元素的大小
            while (l <= mid && r <= right) {
                if (A[l] < A[r]) {
                    tmpArr[t++] = A[l++];
                } else {
                    tmpArr[t++] = A[r++];
                }
            }
    
            // 剩余的加入临时数组
            while (l <= mid) {
                tmpArr[t++] = A[l++];
            }
            // 剩余的加入临时数组
            while (r <= right) {
                tmpArr[t++] = A[r++];
            }
    
            // 把临时数组元素放回原数组
            for (int i = 0; i < t; i++) {
                A[left + i] = tmpArr[i];
            }
    
        }
    }
  • 相关阅读:
    【BZOJ2806】【CTSC2012】—熟悉的文章(二分答案+广义后缀自动机+单调队列优化dp)
    2017-2-15
    2017-2-14
    2017-2-13
    CSS居中
    2017-2-10
    微信小程序
    2017-2-9
    2017-2-8
    基础知识再整理: 01
  • 原文地址:https://www.cnblogs.com/yingpu/p/9266604.html
Copyright © 2011-2022 走看看