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

     using System; 
        using System.Collections.Generic; 
        using System.Linq; 
        using System.Text;
        namespace test
    {
        class QuickSort
        {
            static void Main(string[] args)
            {
                int[] array = { 49, 38, 65, 97, 76, 13, 27 };
                sort(array, 0, array.Length - 1);
                Console.ReadLine();
            }
            /**一次排序单元,完成此方法,key左边都比key小,key右边都比key大。
              
     
    **@param array排序数组 
              
     
    **@param low排序起始位置 
              
     
    **@param high排序结束位置
              
     
    **@return单元排序后的数组 */
            private static int sortUnit(int[] array, int low, int high)
            {
                int key = array[low];
                while (low < high)
                {
                    /*从后向前搜索比key小的值*/
                    while (array[high] >= key && high > low)
                        --high; 
                    /*比key小的放左边*/
                    array[low] = array[high];   
                    /*从前向后搜索比key大的值,比key大的放右边*/
                    while (array[low] <= key && high > low)
                        ++low; 
                    /*比key大的放右边*/
                    array[high] = array[low];
                }
                /*左边都比key小,右边都比key大。//将key放在游标当前位置。//此时low等于high */
                array[low] = key;
                foreach (int i in array)
                {
                    Console.Write("{0}	", i);
                }
                Console.WriteLine();
                return high;
            }    
            /**快速排序 
    *@paramarry 
    *@return */
            public static void sort(int[] array, int low, int high)
            {
                if (low >= high)
                    return; 
                /*完成一次单元排序*/
                int index = sortUnit(array, low, high); 
                /*对左边单元进行排序*/
                sort(array, low, index - 1);
                /*对右边单元进行排序*/
                sort(array, index + 1, high);
            }
        }
    } 
    运行结果:27 38 13 49 76 97 65
    13 27 38 49 76 97 65
      13 27 38 49 65 76 97
    快速排序就是递归调用此过程——在以49为中点分割这个数据序列,分别对前面一部分和后面一部分进行类似的快速排序,从而完成全部数据序列的快速排序,最后把此数据序列变成一个有序的序列,根据这种思想对于上述数组A的快速排序的全过程如图6所示:
    初始状态 {49 38 65 97 76 13 27} 进行一次快速排序之后划分为 {27 38 13} 49 {76 97 65} 分别对前后两部分进行快速排序{27 38 13} 经第三步和第四步交换后变成 {13 27 38} 完成排序。{76 97 65} 经第三步和第四步交换后变成 {65 76 97} 完成排序。
  • 相关阅读:
    sum left join 多次引发的问题
    WPF之Binding基础三 Binding的路径Path
    解决Android Studio启动不了的办法
    指向常量的指针和常量指针的区别简单理解
    简单的字符串操作
    QT问答
    log4qt使用示例
    在线代码库
    Qt5的windows开放环境准备
    QT 调试技术
  • 原文地址:https://www.cnblogs.com/blacop/p/6012811.html
Copyright © 2011-2022 走看看