• 快速排序


    快速排序

    (1)基本思想:选择一个基准元素,通常选择第一个元素或者最后一个元素,通过一趟扫描,将待排序列分成两部分,一部分比基准元素小,一部分大于等于基准元素,此时基准元素在其排好序后的正确位置,然后再用同样的方法递归地排序划分的两部分。

    (2)实例:

    (3)用java实现

    [plain] view plaincopy
     
    1. public class quickSort {  
    2.   
    3.   inta[]={49,38,65,97,76,13,27,49,78,34,12,64,5,4,62,99,98,54,56,17,18,23,34,15,35,25,53,51};  
    4.   
    5. public quickSort(){  
    6.   
    7.     quick(a);  
    8.   
    9.     for(int i=0;i<a.length;i++)  
    10.   
    11.        System.out.println(a[i]);  
    12.   
    13. }  
    14.   
    15. publicint getMiddle(int[] list, int low, int high) {     
    16.   
    17.             int tmp = list[low];    //数组的第一个作为中轴     
    18.   
    19.             while (low < high) {     
    20.   
    21.                 while (low < high && list[high] >= tmp) {     
    22.   
    23.                     high--;     
    24.   
    25.                 }     
    26.   
    27.                 list[low] = list[high];   //比中轴小的记录移到低端     
    28.   
    29.                 while (low < high && list[low] <= tmp) {     
    30.   
    31.                     low++;     
    32.   
    33.                 }     
    34.   
    35.                 list[high] = list[low];   //比中轴大的记录移到高端     
    36.   
    37.             }     
    38.   
    39.            list[low] = tmp;              //中轴记录到尾     
    40.   
    41.             return low;                   //返回中轴的位置     
    42.   
    43.         }    
    44.   
    45. publicvoid _quickSort(int[] list, int low, int high) {     
    46.   
    47.             if (low < high) {     
    48.   
    49.                int middle = getMiddle(list, low, high);  //将list数组进行一分为二     
    50.   
    51.                 _quickSort(list, low, middle - 1);        //对低字表进行递归排序     
    52.   
    53.                _quickSort(list, middle + 1, high);       //对高字表进行递归排序     
    54.   
    55.             }     
    56.   
    57.         }   
    58.   
    59. publicvoid quick(int[] a2) {     
    60.   
    61.             if (a2.length > 0) {    //查看数组是否为空     
    62.   
    63.                 _quickSort(a2, 0, a2.length - 1);     
    64.   
    65.         }     
    66.   
    67.        }   
    68.   
    69. }  
    70.   
  • 相关阅读:
    React+AntdUi实现《好客租房系统》首页01
    javaScript学习day04——关于函数
    javaScript学习day03
    javascript学习day01
    第五章回溯法
    第四章作业
    第四章上机实践报告
    算法第三章动态规划
    PTA 7-3 编辑距离问题 (30 分)
    7-3 两个有序序列的中位数 (20 分) log n的解法
  • 原文地址:https://www.cnblogs.com/xuehen/p/4635876.html
Copyright © 2020-2023  润新知