免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
最近访问板块 发新帖
查看: 848 | 回复: 0
打印 上一主题 下一主题

算法导论学习笔记--快速排序 [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2009-05-18 14:00 |只看该作者 |倒序浏览

               
               
                [root@mip-123456 quick_sort]# cat quick.c
#include stdio.h>
#define N 10
inline int exchange(int* a,int* b)
{
  int tmp;
  tmp = *a;
  *a = *b;
  *b = tmp;
  return 0;
}
int partition(int* A,int p ,int r)
{
  int tmp = 0;
  int i = 0;
  int j = 0;
  tmp = *(A+r);
  //printf("tmp is %d\n",tmp);
  i = p-1;

  for(j=p;jr;j++)
   {
//    printf("A[%d] is %d\n",j,*(A+j));
     if(A[j]tmp)
      {
         i++;
    //     printf("before exchange %d %d\n",*(A+i),*(A+j));
            exchange(A+i,A+j);
     //    printf("after exchange %d %d\n",*(A+i),*(A+j));
         }
     }
   exchange(A+i+1,A+r);
   
   return i+1;
}
int quick_sort(int* A,int p,int r)
{
  int q = 0;
// printf("p = %d,r=%d\n",p,r);
// printf("A[%d] = %d,A[%d] = %d\n",p,*(A+p),r,*(A+r));
  if(pr)
    {
       q = partition(A,p,r);
       quick_sort(A,p,q-1);
       quick_sort(A,q+1,r);
    }
   return 0;
}
int main()
{
int i = 0;
int A[N] = {16,14,10,8,7,9,3,2,4,1};

printf("before sort:\n");
for(i=0;i10;i++)
   printf("%5d",A);
quick_sort(A,0,N-1);
printf("\nafter sort:\n");
for(i=0;iN;i++)
   printf("%5d",A);
printf("\n");
return 0;
}
[root@mip-123456 quick_sort]# ./quick
before sort:
   16   14   10    8    7    9    3    2    4    1
after sort:
    1    2    3    4    7    8    9   10   14   16


本文来自ChinaUnix博客,如果查看原文请点:http://blog.chinaunix.net/u2/76292/showart_1932105.html
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

北京盛拓优讯信息技术有限公司. 版权所有 京ICP备16024965号-6 北京市公安局海淀分局网监中心备案编号:11010802020122 niuxiaotong@pcpop.com 17352615567
未成年举报专区
中国互联网协会会员  联系我们:huangweiwei@itpub.net
感谢所有关心和支持过ChinaUnix的朋友们 转载本站内容请注明原作者名及出处

清除 Cookies - ChinaUnix - Archiver - WAP - TOP