Chinaunix首页 | 论坛 | 博客
  • 博客访问: 130823
  • 博文数量: 70
  • 博客积分: 2510
  • 博客等级: 少校
  • 技术积分: 380
  • 用 户 组: 普通用户
  • 注册时间: 2009-11-24 18:53
文章分类
文章存档

2015年(8)

2014年(14)

2011年(1)

2010年(21)

2009年(26)

我的朋友

分类: C/C++

2010-05-07 19:17:36

#include
//冒泡排序
void bubbleSort(int* s,int n)
{
 for(int i=1;i {
  for(int j=0;j  {
   if(s[j+1]   {
    int temp = s[j+1];
    s[j+1]=s[j];
    s[j]=temp;
   }
  }
 }
}
//改进后的冒泡排序
void bubbleSort_2(int *s,int n)
{
 bool exchange=true;
 int i=1;
 while(exchange)
 {
  exchange=false;
  for(int j=0;j  {
   if(s[j+1]   {
    int temp = s[j+1];
    s[j+1]=s[j];
    s[j]=temp;
    exchange=true;
   }
  }
  i++;
 }
}
//直接插入排序
void directInserSort(int *s,int n)
{
 for(int i=1;i {
  int tm = s[i];//这里注意要要用一个变量把值暂存起来,要不然值会被冲掉
  for(int j=i-1;j>=0&&s[j]>tm;j--)
  {
  
    int temp = s[j+1];
    s[j+1]=s[j];
    s[j]=temp;
   
  }
  s[j+1]=tm;
 }
}
//折半插入排序
void halfInsertSort(int *s,int n)
{
 for(int i=1;i {
  int low=0;
  int high=i-1;
  int tm =s[i];
  while(low<=high)//注意等号
  {
   int mid = (high+low)/2;
   if(tm>s[mid])
   {
    low=mid+1;
   }
   else
   {
    high=mid-1;
   }
  }
  for(int j=i-1;j>=high+1;j--)
  {
    int temp = s[j+1];
    s[j+1]=s[j];
    s[j]=temp;
  }
  s[high+1]=tm;
 
 }
}
//希尔排序
void shellSort(int *s,int n)
{
 for(int d=n/2;d>0;d=d/2)
 {
  for(int i=d;i  {
   int tm=s[i];
   for(int j=i-d;j>=0&&s[j]>tm;j=j-d)
   {
    int temp = s[j+d];
    s[j+d]=s[j];
    s[j]=temp;
   }
   s[j+d]=tm;
  }
 
 } 
}

//快速排序一次分割
int partion(int *s,int low,int high)
{
  int tm=s[low];
  while(low  {
  while(low=tm)
  {
   --high;
  }
  if(low  {
   s[low++]=s[high];
  }
  while(low  {
   ++low;
  }
  if(low  {
   s[high--]=s[low];
  }
  }
  s[low]=tm;
  return low;
}
//快速排序
void quikSort(int *s,int low,int high)
{
 if(low {
  int pos=partion(s,low,high);
  quikSort(s,low,pos-1);
  quikSort(s,pos+1,high);
 }
 
}
//选择排序
void selectSort(int *s,int n)
{
 for(int i=0;i {
  int k=i;
  for(int j=i+1;j  {
   if(s[j]   {
    k=j;
   }  
  }
  if(k!=i)
  {
    int temp = s[k];
    s[k]=s[i];
    s[i]=temp;
  }
 }
}
///堆排序
void shift(int a[] , int i , int m)
{
int k , t;
    t = a[i]; k = 2 * i +1;
    while (k < m)
    {
        if ((k < m - 1) && (a[k] < a[k+1])) k ++;
        if (t < a[k]) {a[i] = a[k]; i = k; k = 2 * i + 1;}
        else break;
 }
    a[i] = t;
}
void heap(int a[] , int n)  //a 为排序数组,n为数组大小(编号0-n-1)
{
int i , k;
 for (i = n/2-1; i >= 0; i --) shift(a , i , n);
 
 for (i = n-1; i >= 1; i --)
    {
  k = a[0]; a[0] = a[i]; a[i] = k;
  shift(a , 0 , i);
    }
}
阅读(767) | 评论(0) | 转发(0) |
给主人留下些什么吧!~~