• 快速排序


       快速排序是在实践中最快的已知算法,它的平均运行时间是O(NlogN),该算法的基本思想如下:

        1、如果数组S中的元素个数为0或者1,则直接返回

        2、在原来要排序的数组中选取一个元素v,称为枢纽元

        3、将S-{v}分成两个不想交的集合:S1为小于等于v的元素,S2为大于等于v的元素

        4、重复上面的步骤

       因此可以看出,和归并算法一样,快速排序也是递归的。

        代码如下:

       

    #include<iostream>
    
    using namespace std;
    
    #define Cutoff 3
    
    int A[13] = {81,94,11,96,12,35,17,95,28,58,41,75,15};
    
    void Swap(int &a, int &b)
    {
       int c;
      c = a;
      a = b;
      b = c;
    }
    
    void InsetionSort (int A[], int N)   //插入排序
    {
    	int j, p;
    	int Tmp;
    	for (p = 1; p < N; p++)
    	{
    	   Tmp = A[p];
    	   for(j = p; j > 0 && A[j - 1] > Tmp; j--)
    	       A[j] = A[j - 1];
    	   A[j] = Tmp;
    	}
    }
    
    
    int Median (int A[],int Left, int Right)   //实现三数中值分割,选取枢纽元
    {
       int Center = (Left + Right ) / 2;
    
       if(A[Left] > A[Center])
    	   Swap(A[Left] , A[Center]);
       if(A[Left] > A[Right])
    	   Swap(A[Left] , A[Right]);
       if(A[Center] > A[Right])
    	   Swap(A[Center] , A[Right]);
    
       /* A[Left] <= A[Center] <= A[Right] */
       Swap(A[Center], A[Right - 1]);    //把枢纽元放在倒数第二个
       return A[Right - 1];
    }
    
    void Qsort (int A[], int Left, int Right)
    {
       int i, j;
       int Pivot;
       if(Left + Cutoff <= Right)
       {
          Pivot = Median(A,Left,Right);
    	  i = Left; j = Right - 1;
    	  for( ; ; )
    	  {
    		  while(A[++i] < Pivot) { }
    		  while(A[--j] > Pivot) { }
    		  if(i < j)
    			  Swap(A[i], A[j]);
    		  else
    			  break;
    	  }
    	  Swap(A[i], A[Right - 1]);   // 恢复枢纽元的位置
    
    	  Qsort (A, Left, i - 1);
    	  Qsort (A, i + 1, Right);
       }
       else
       InsetionSort (A + Left, Right - Left + 1);
    }
    
    void Quicksort(int A[], int N)
    {
       Qsort (A, 0, N - 1);
    }
    
    int main ()
    {
      Quicksort (A, 13);
      for(int i = 0; i != 13; ++i)
        {
           cout << A[i] << "  ";
        }
        cout << endl;
       return 0;
    }
    

        上面的代码显示,到最后是用插入排序来处理小数组的。

            夜深了,,,

          也很深,很黑

       

  • 相关阅读:
    用遗传算法解决子集和问题
    XML映射配置文件
    generator插件配置方式使用
    声明
    spring IOC简单分析
    模板模式
    原型模式
    委派模式,策略模式
    单例模式2
    单例模式
  • 原文地址:https://www.cnblogs.com/1242118789lr/p/6858076.html
Copyright © 2020-2023  润新知