zoukankan      html  css  js  c++  java
  • 快速排序

    快速排序使用分治法策略来把一个序列分为两个子序列
    算法步骤:
    1. 从数列中挑出一个元素,称为 "基准"(pivot)
    2. 重新排序数列,所有元素比基准值小的摆放在基准前面,所有元素比基准值大的摆在基准的后面 (相同的数可以到任一边)。在这个分割结束之后,该基准就处于数列的中间位置。这个称为分割(partition)操作
    3. 递归地(recursive)把小于基准值元素的子数列和大于基准值元素的子数列排序
    * 比较复杂度:O(n㏒n)
    * 交换(赋值)复杂度:O(n㏒n)
    * 优点:比一般的排序都要快

    public static void quickSort(Integer[] array) {   
        if (array == null || array.length== 0) {   
             return;   
        }   
        quickSort(array,0,array.length-1);         
    }
    private static void quickSort(Integer[] array, final int start, final int end){
            //数组长度<=1退出
            if(start>=end){
                return;
            }
            //数组长度==2,比较两个元素的大小
            if(end-start==1){
                if(array[start]>array[end]){
                    swap(array,start,end);
                }
                return;
            }
            
            //用来进行比较的数
            int compareNumber = array[start];
            int middlePosition = 0;
            int i = start;
            int j = end;
            for(;;i++,j--){
                
                //从数组首端开始迭代(不包括compareNumber),如果数组的数<compareNumber,不做移动
                while(array[i]<compareNumber&&i<j){
                    i++;
                }        
                //从数组尾端迭代,如果数组的数>=compareNumber,不做移动
                
                while(array[j]>compareNumber&&i<j){
                    j--;
                }            
                
                if(i>=j){
                    if(array[j]>compareNumber){
                        middlePosition = j;
                    }else{
                        middlePosition = (j+1);
                    }
                    break;
                }
                //从数组首端开始迭代,得到大于compareNumber的数array[i],此时从尾端迭代直至得到<=compareNumber的数
                //array[j],交换这两个数的位置,然后继续迭代
                swap(array,i,j);
            }
            //递归排序
            quickSort(array,start,middlePosition-1);
            quickSort(array,middlePosition,end);
        }
    public static void swap(Object[] array,int a,int b){
        Object temp = array[a];
        array[a] = array[b];
        array[b] = temp;
    }
  • 相关阅读:
    uva 1362(区间dp+计数)
    uva 11174(排列组合+搜索)
    简单递推系列 uva习题
    基本计数方法系列 uva习题
    Codeforces Round #209 (Div. 2) Problem A Table(找规律)
    CodeChef November Challenge 2013 解题报告
    2012 chengdu现场赛 Browsing History HDU4464(简单字符串)
    CodeChef TechFest 2013 Cool Numbers(搜索)
    CodeChef Inscription 2013 Wonderland jewellery(简单题)
    页面滚动marquee标签
  • 原文地址:https://www.cnblogs.com/tangyanbo/p/4282352.html
Copyright © 2011-2022 走看看