Chinaunix首页 | 论坛 | 博客
  • 博客访问: 386354
  • 博文数量: 83
  • 博客积分: 1650
  • 博客等级: 上尉
  • 技术积分: 861
  • 用 户 组: 普通用户
  • 注册时间: 2010-10-18 18:22
文章分类
文章存档

2021年(1)

2016年(1)

2015年(2)

2014年(3)

2013年(12)

2012年(16)

2011年(18)

2010年(30)

分类: LINUX

2011-04-05 00:43:56

#include
#include
struct node
{
 int key;
}r[20];
struct rnode
{
 int key;
 int point;
};
main()
{
 void print(struct node a[20],int n);
 int creat();
 void shell(struct node a[20],int n);
 int hoare(struct node a[20],int l,int h);
 void quick1(struct node a[20],int n);
 void quick2(struct node a[20],int l,int h);
 void heap(struct node a[20],int i,int m);
 void heapsort(struct node a[20],int n);
 void merges(struct node a[20],struct node a2[20],int h1,int mid,int h2);
 void mergepass(struct node a[20],struct node a2[20],int l,int n);
 void mergesort(struct node a[20],int n);
 int yx(int m,int i);
 int radixsort(struct rnode a[20],int n);
 int num,l,h,c;
 struct rnode s[20];
 c=1;
 while(c!=0)
 {
  printf("        主菜单                       \n");
  printf("   1    输入关键字,以-9999表示结束。\n");
  printf("   2    希尔排序                     \n");
  printf("   3    非递归的快速排序             \n");
  printf("   4    递归的快速排序               \n");
  printf("   5    堆排序                       \n");
  printf("   6    归并排序                     \n");
  printf("   7    基数排序                     \n");
  printf(" 输入选择    (1--7,0表示结束):         ");
  scanf("%d",&c);
  switch(c)
  {
  case 1:num=creat();print(r,num);break;
  case 2:shell(r,num);print(r,num);break;
  case 3:quick1(r,num);print(r,num);break;
  case 4:l=0;h=num-1;quick2(r,l,h);
   printf("output quick2sort result:\n");
   print(r,num);break;
  case 5:heapsort(r,num);break;
  case 6:mergesort(r,num);print(r,num);break;
  case 7:radixsort(s,num);
  }
 }
}//main end
void print(struct node a[20],int n)
{
 int i;
 for(i=0;i  printf("%5d",a[i ].key);
 printf("\n");
}//print end
int creat()
{
 int i,n;
 n=0;
 printf("input keys");
 scanf("%d",&i);
 while(i!=-9999)
 {
  r[n].key=i;
  n++;
  scanf("%d",&i);
 }
 return(n);
}//creat end
void shell(struct node a[20],int n)//希尔排序
{
 int i,j,k;
 for(i=n;i>=1;i--)
  a[i].key=a[i-1].key;
 k=n/2;
 while(k>=1)
 {
  for(i=k+1;i<=n;i++)
  {
   a[0].key=a[i].key;
   j=i-k;
   while((a[j].key>a[0].key)&&(j>=0))
   {
    a[j+k].key=a[j].key;
    j=j-k;
   }
   a[j+k]=a[0];
  }
  k=k/2;
 }
 for(i=0;i  a[i].key=a[i+1].key;
 printf("输出希尔排序的结果:\n");
}//shell end
////////////////////快速排序///////////////////////////
int hoare(struct node a[20],int l,int h)//分区处理函数
{
 int i,j;
 struct node x;
 i=l;
 j=h;
 x.key=a[i].key;
 do
 {
  while((i=x.key))
   j--;
  if(i  {
   a[i].key=a[j].key;
   i++;
  }
  while((i   i++;
  if(i  {
   a[j].key=a[i].key;
   j--;
  }
 }while(i a[i].key=x.key;
 return(i);
}//hoare end
void quick1(struct node a[20],int n)
{
 int i,l,h,tag,top;
 int s[20][2];
 l=0;h=n-1;tag=1;top=0;
 do
 {
  while(l  {
   i=hoare(a,l,h);
   top++;
   s[top][0]=i+1;
   s[top][1]=h;
   h=h-1;
  }
  if(top==0)
   tag=0;
  else
  {
   l=s[top][0];
   h=s[top][1];
   top--;
  }
 }while(tag==1);
 printf("输出非递归快速排序结果:\n");
}//quick end
void quick2(struct node a[20],int l,int h)//递归的快速排序
{
 int i;
 if(l {
  i=hoare(a,l,h);
  quick2(a,l,i-1);
  quick2(a,i+1,h);
 }
}//quick2 end
////////////////////快速排序结束////////////////////////
////////////////////堆排序函数//////////////////////////
void heap(struct node a[20],int i,int m)//调整堆的函数
{
 struct node x;
 int j;
 x.key=a[i].key;
 j=2*i;
 while(j<=m)
 {
  if(j   if(a[j].key>a[j+1].key)
    j++;
  if(a[j].key  {
   a[i].key=a[j].key;
   i=j;
   j=2*i;
  }
  else
   j=m+1;
 }
 a[i].key=x.key;
}//heap end
void heapsort(struct node a[20],int n)//堆排序的主体函数
{
 int i,v;
 struct node x;
 for(i=n;i>0;i--)
  a[i].key=a[i-1].key;
 for(i=n/2;i>=1;i--)
  heap(a,i,n);
 printf("输出堆排序结果:\n");
 for(v=n;v>=2;v--)
 {
  printf("%5d",a[1].key);
  x.key=a[1].key;
  a[1].key=a[v].key;
  a[v].key=x.key;
  heap(a,1,v-1);
 }
 printf("%5d",a[1].key);
 for(i=0;i  a[i].key=a[i+1].key;
}//heapsort end
/////////////////堆排序函数结束///////////////////
//////////////////归并函数////////////////////////
void merges(struct node a[20],struct node a2[20],int h1,int mid,int h2)
//归并排序的核心算法
{
 int i,j,k;
 i=h1;j=mid+1;k=h1-1;
 while((i<=mid)&&(j<=h2))
 {
  k=k+1;
  if(a[i].key<=a[j].key)
  {
   a2[k].key=a[i].key;
   i++;
  }
  else
  {
   a2[k].key=a[j].key;
   j++;
  }
 }
 while(i<=mid)
 {
  k++;
  a2[k].key=a[i].key;
  i++;
 }
 while(j<=h2)
 {
  k++;
  a2[k].key=a[j].key;
  i++;
 }
}//merges end
void mergepass(struct node a[20],struct node a2[20],int l,int n)
//一趟归并
{
 int j,i,h1,mid,h2;
 i=0;
 while((n-i)>=2*l)
 {
  h1=i;
  mid=h1+l-1;
  h2=i+2*l-1;
  merges(a,a2,h1,mid,h2);
  i=i+2*l;
 }
 if((n-i)<=l)
  for(j=i;j<=n;j++)
   a2[j].key=a[j].key;
 else
 {
  h1=i;
  mid=h1+l-1;
  h2=n-1;
  merges(a,a2,h1,mid,h2);
 }
}//mergepass end
void mergesort(struct node a[20],int n)
{
 int l;
 struct node a2[20];
 l=1;
 while(l {
  mergepass(a,a2,l,n);
  l=2*l;
  mergepass(a2,a,l,n);
  l=2*l;
 }
 printf("输出归并排序的结果:\n");
}//mergesort end
///////////////归并函数结束///////////////
///////////////基数排序///////////////////
int yx(int m,int i)//分离关键字倒数第i位有效数字的算法
{
 int x;
 switch(i)
 {
 case 1:x=m%10;break;
 case 2:x=(m%100)/10;break;
 case 3:x=(m%1000)/100;break;
 case 4:x=(m%10000)/1000;break;
 }
 return(x);
}//yx end
int radixsort(struct rnode a[20],int n)
{
 int f[11],e[11],i,j,k,l,p,d,t;
 for(i=1;i<=n;i++)
 {
  a[i].key=r[i-1].key;
  a[i].point=i+1;
 }
 a[n].point=0;
 p=1;
 printf("输出关键字有效位数 d\n");
 scanf("%d",&d);
 printf("输出基数排序的结果:\n");
 for(i=1;i<=d;i++)
 {
  for(j=0;j<=10;j++)
  {
   f[j]=0;
   e[j]=0;
  }
  while(p!=0)
  {
   k=yx(a[p].key,i);
   if(f[k]==0)
   {
    f[k]=p;
    e[k]=p;
   }
   else
   {
    l=e[k];
    a[l].point=p;
    e[k]=p;
   }
   p=a[p].point;
  }
  j=0;
  while(f[j]==0)
   j++;
  p=f[j];t=e[j];
  while(j<10)
  {
   j++;
   while((j<10)&&(f[j]==0))
    j++;
   if(f[j]!=0)
   {
    a[t].point=f[j];
    t=e[j];
   }
  }
  a[t].point=0;
  t=p;
  while(t!=0)
  {
   printf("%5d",a[t].key);
   t=a[t].point;
  }
  printf("\n");
 }
 return(p);
}
阅读(932) | 评论(0) | 转发(0) |
给主人留下些什么吧!~~