【基础排序】梳排序

梳排序(Comb sort)是一种不稳定排序算法,改良自泡沫排序快速排序,其要旨在于消除乌龟,亦即在阵列尾部小数值,这些数值是造成泡沫排序缓慢的主因。相对地,兔子,亦即在阵列前端的大数值,不影响泡沫排序的效能。

在泡沫排序中,只比较阵列中相邻的二项,即比较的二项的间距(Gap)是1,梳排序提出此间距其实可大于1,改自插入排序希尔排序同样提出相同观点。梳排序中,开始时的间距设定为阵列长度,并在循环中以固定比率递减,通常递减率设定为1.3。在一次循环中,梳排序如同泡沫排序一样把阵列从首到尾扫描一次,比较及交换两项,不同的是两项的间距不固定于1。如果间距递减至1,梳排序假定输入阵列大致排序好,并以泡沫排序作最后检查及修正。

 

 

#include <iostream>
#include <time.h>
using namespace std;

void combsort(int *arr, int size) 
{
 
  double shrink_factor = 1.247330950103979;
  int gap = size;
  int swapped = 1;
  int swap;
  int i;
 
  while ((gap > 1) || swapped) 
  {
    if (gap > 1) 
	{
		gap = gap / shrink_factor;
	}
 
    swapped = 0; 
    i = 0;
 
    while ((gap + i) < size) 
	{
      if(arr[i]-arr[i+gap] > 0) 
	  {
        swap = arr[i];
        arr[i] = arr[i+gap];
        arr[i+gap] = swap;
        swapped = 1;
      }
      ++i;
    }
  }
}


void print(int a[],int n)          
{          
    for(int i=0; i<n; i++)          
    {          
        cout<<a[i]<<" ";          
    }          
    cout << endl;          
}          
        
        
void main()          
{          
    int a[10];    
    srand((unsigned)time(NULL));//初始化随机数      
    
    for(int i=0; i<10; i++)    
    {    
        a[i]=rand()%20;    
    }    
    cout << "排序前:";          
    print(a,sizeof(a)/sizeof(a[0]));        
        
    int n=sizeof(a)/sizeof(a[0]);        
    combsort(a,n);     
        
    cout << "排序后:";       
    print(a,sizeof(a)/sizeof(a[0]));          
}      


 

你可能感兴趣的:(【基础排序】梳排序)