热点网|医学教育网|北京pk10开奖直播 pk10开奖直播 北京赛车pk10 pk10开奖直播 北京赛车pk10 PK10开奖直播 北京赛车pk10开奖直播 北京pk10 北京pk10

快速排序里的学问:霍尔快排的实现

霍尔快排的C语言实现
服务器君一共花费了218.064 ms进行了5次数据库查询>,努力地为您提供了这个页面>>>>。
试试阅读模式>?希望听取您的建议

专题的前一篇讲了快速排序的始祖——霍尔快排>>,那么这里就简单地实现一下霍尔快排。

补充说明下>>,快排的一个核心步骤是选取枢纽元>,通常的做法是将第一个元素用作枢纽元>,《算法导论》里的快排例子和Hoare快排都是这种枢纽元选择。先撇开效率不说>,我们先看看Hoare快排的实现:

#include "stdio.h"
#include "math.h"
#include "stdlib.h"

int num = 10;

void PrintArray(int arr[])
{
    int i;
	for(i=0; i < num; ++i)
	{
	    printf("%d ", arr[i]);
	}
}

//一趟快排之后>,以枢纽为分隔,左边的<=枢纽, 右边的>=枢纽
int Partition(int *arr, int beg, int end)
{
	int low = beg, high = end;
	//选定枢轴
	int sentinel = arr[beg];
	while(low < high)
	{
	    //printf("\n    定点取arr[%d]的值,设为 sentinel(%d)", low, sentinel );
	    //printf("\n    比sentinel(%d)大的都丢到右边", sentinel);
	    //比枢纽小的交换到低端
		while(low < high && arr[high]>=sentinel)
		{
            //printf("\n    arr[%d](%d) >= sentinel(%d)", high, arr[high], sentinel);
		    --high;
		    //printf(". high自减为%d, 此时 arr[high] 为 %d", high, arr[high]);
		}
		arr[low] = arr[high];
		//printf("\n    赋值-> arr[low](arr[%d]) = arr[high](arr[%d]) = %d", low, high, arr[low]);
		//printf("\n    比sentinel(%d)小的都丢到左边", sentinel);
		//比枢纽大的交换到高端
		while(low < high && arr[low]<=sentinel)
		{

		    //printf("\n    arr[%d](%d) <= sentinel(%d)", low, arr[low], sentinel);
		    ++low;
		    //printf(". low自增为%d, 此时 arr[low] 为 %d", low, arr[low]);
		}
		arr[high] = arr[low];
		//printf("\n    赋值-> arr[high](arr[%d]) = arr[low](arr[%d]) = %d", high, low, arr[high]);
	}
	arr[low] = sentinel;

	printf("\n排序过程:");
	PrintArray(arr);
	return low;
}

void QuickSort(int *arr, int beg, int end)
{
	if(beg < end)
	{
		int pivot = Partition(arr, beg, end);
		//分治思想>,递归排序
		QuickSort(arr, beg, pivot-1);
		QuickSort(arr, pivot+1, end);
	}
}

int main()
{
    int i;
	int arr[10];

	srand(time(0));
    for(i=0; i < 10; i++)
    {
        arr[i] = rand()%100+1;
        //printf("%d ", rand()%100+1);
    }
    printf("初始数组:");
    PrintArray(arr);

	QuickSort(arr, 0, num-1);

	printf("\n最后结果:");
	PrintArray(arr);

	return 0;
}

程序运行结果为:

初始数组:80 16 97 6 12 92 31 52 54 89
排序过程: [ 54 16 52 6 12 31 ] 80 [ 92 97 89 ]
排序过程:[ 31 16 52 6 12 ] 54 [ 80 92 97 89 ]
排序过程:[ 12 16 6 ] 31 [ 52 54 80 92 97 89 ]
排序过程:[ 6 ] 12 [ 16 31 52 54 80 92 97 89 ])
排序过程:[ 6 12 16 31 52 54 80 89 ] 92 [ 97 ]
最后结果:6 12 16 31 52 54 80 89 92 97
Process returned 0 (0x0)   execution time : 0.384 s
Press any key to continue.

排序的思路是,选定一个枢纽元>,比枢纽元大的全部丢到右边>>>,比枢纽元小的全部丢到左边>,可以看看下图:

霍尔快排的思路清晰了吧?

前面提到了,《算法导论》里的快排例子和Hoare快排都是将第一个元素用作枢纽元的排序,当然也有其它选择法>,后面会介绍到>。

延伸阅读

此文章所在专题列表如下:

  1. 快速排序里的学问:从猜数字开始
  2. 快速排序里的学问:再看看称球问题
  3. 快速排序里的学问:信息熵
  4. 快速排序里的学问:快速排序的过程
  5. 快速排序里的学问:霍尔与快速排序
  6. 快速排序里的学问:霍尔快排的实现
  7. 快速排序里的学问:枢纽元选择与算法效率
  8. 快速排序里的学问:随机化快排

本文地址:http://www.jzjxzzjx.com/librarys/veda/detail/2396,欢迎访问原出处。

不打个分吗?

转载随意>,但请带上本文地址:

http://www.jzjxzzjx.com/librarys/veda/detail/2396

如果你认为这篇文章值得更多人阅读,欢迎使用下面的分享功能>。
小提示:您可以按快捷键 Ctrl + D>,或点此 加入收藏>>。

阅读一百本计算机著作吧,少年

很多人觉得自己技术进步很慢>,学习效率低,我觉得一个重要原因是看的书少了>>>。多少是多呢>?起码得看3、4、5、6米吧。给个具体的数量>>,那就100本书吧>。很多人知识结构不好而且不系统,因为在特定领域有一个足够量的知识量+足够良好的知识结构,系统化以后就足以应对大量未曾遇到过的问题>。

奉劝自学者:构建特定领域的知识结构体系的路径中再也没有比学习该专业的专业课程更好的了>。如果我的知识结构体系足以囊括面试官的大部分甚至吞并他的知识结构体系的话,读到他言语中的一个词我们就已经知道他要表达什么>,我们可以让他坐“上位”毕竟他是面试官>>>,但是在知识结构体系以及心理上我们就居高临下>。

所以,阅读一百本计算机著作吧>,少年>!

《程序员修炼之道:从小工到专家》 亨特(Andrew Hunt) (作者), 托马斯(David Thomas) (作者), 马维达 (译者)

《程序员修炼之道:从小工到专家》内容简介:《程序员修炼之道》由一系列独立的部分组成>,涵盖的主题从个人责任>、职业发展>>,知道用于使代码保持灵活、并且易于改编和复用的各种架构技术,利用许多富有娱乐性的奇闻轶事>、有思想性的例子及有趣的类比>>,全面阐释了软件开发的许多不同方面的最佳实践和重大陷阱。无论你是初学者>,是有经验的程序员>,还是软件项目经理,《程序员修炼之道:从小工到专家》都适合你阅读>。

更多计算机宝库...

  • 海门叠石桥国际家纺城--江苏频道--人民网 2018-05-23
  • 主持人资料库——柴静 2018-05-23
  • 森林防火有了新“利器” 2018-05-23
  • 港媒称台战机“日晒雨淋” 台军将领出面否认 2018-05-22
  • 怎样和陈意涵袁姗姗一样拥有完美裸妆肤感? 2018-05-22
  • 《东北树木彩色图志》首次载入我国新发现植物“青姬木” 2018-05-22
  • 网约车司机无证上岗拟纳入失信黑名单无证司机失信 2018-05-20
  • 300余名澳门中学生参加国旗手训练营(组图) 2018-05-20
  • 法前总统萨科齐遭拘 或因利比亚前要人递新证据 2018-05-20
  • 美媒称中国新人婚纱摄影很疯狂:有的仿如电影拍摄现场 2018-05-19
  • 立陶宛举行“汉语桥”中文比赛 2018-05-19
  • 上海嘉禾2017秋季艺术品拍卖会 2018-05-18
  • 海归回国就业创业遇到困难怎么办他帮海归找工作就业创业留学生海归 2018-05-18
  • 扛不住了?台当局拟放宽许可条件鼓励陆客赴台 2018-05-17
  • 美名校毕业典礼竞邀女性演讲者 希拉里将前往耶鲁希拉里耶鲁演讲者 2018-05-16
  • ASP300源码下载 | 微信红包群 | 设计 | 冠珠陶瓷 | 科技 | 北京赛车pk10微信源码 | 挖段子网 | 厦门旅游景点 | 旅游中国新闻网 | 钛媒体 | 健康网hsdcba | 每天资讯 | 广西农业技术信息 | 农业种植技术 |