zoukankan      html  css  js  c++  java
  • 基础算法(二):堆排序,快速排序

    基本的算法

    堆排序,快速排序

    堆排序:

    package alg;
    
    import java.util.Arrays;
    
    /**
     * @author zha
     * 算法的复杂度为O(nlogn)
     */
    public class HeapSort {
    
        public static void main(String[] args) {
            int[] array = { 5, 2, 4, 6, 1, 3, 23, 434, 55, 6, 788, 89, 0 };
            heapSort(array, 0 , array.length- 1);
            System.out.println(Arrays.toString(array));
    
        }
    
        private static void heapSort(int[] array, int from, int to) {
            buildHeap(array,from,to);
            int length = to - from +1;
            swap(array,from,to);
            while(length > 1){
                for (int i = to - 1; i >= from; i--) {
                    buildHeap(array, from, i);
                    swap(array, i, from);
                }
                length--;
            }
            
        }
    
        private static void buildHeap(int[] array, int from, int to) {
            int length = to - from +1;
            int mid = from + (length >> 1);
            for (int i = mid ; i >= 0 ;i--) {
                MAXHeap(array,from ,to, i);
            }
        }
    
        private static void MAXHeap(int[] array, int from, int to, int index) {
            int left = left(index);
            int right = right(index);
            int lagest = 0;
            if(left <= to && array[left] > array[index]){
                lagest = left;
            }else{
                lagest = index;
            }
            
            if(right <= to && array[right] > array[lagest]){
                lagest = right;
            }
            
            if(lagest != index){
                swap(array,index,lagest);
                MAXHeap(array, from,to,lagest);
            }
        }
    
        private static void swap(int[] array, int i, int j) {
            int temp = array[i];
            array[i] = array[j];
            array[j] = temp;
            
        }
    
        private static int left(int i){
            return 2*(i+1)-1;
        }
        
        private static int right(int i){
            return 2*(i+1);
        }
    }

    快速排序:

  • 相关阅读:
    服务器出现大量的127.0.0.1:3306 TIME_WAIT连接 解决方法 [转载]
    phpize安装php扩展CURL
    linux位数查看
    Linux下Sublime Text 3的安装
    ECstore后台报表显示空白问题解决办法
    centos 上安装phpstorm
    Nginx禁止目录执行php文件权限
    vue 动画
    vue的路由
    组件的传值 组件之间的通讯
  • 原文地址:https://www.cnblogs.com/zhailzh/p/4096221.html
Copyright © 2011-2022 走看看