排序算法---快速排序
来源:互联网 发布:淘宝拍衣服的要求 编辑:程序博客网 时间:2024/06/05 17:34
因为最近在看《代码之美》--beautiful code 这本书,看到了许多领域里的大牛对自己的敲码历史进行总结,选出自己认为写过的最优雅,高效的代码。看完之后不得不心生感叹,不得不对这些先辈们竖起大拇指。
说到正题,还是回归到排序算法这里,我们常见的排序算法包括:
<1>交换排序(以升序为准)
1.冒泡排序:从头开始,相邻两个数值进行比较,如果后一个元素的值比前一个元素的值小的话交换位置。
2.快速排序(也是我今天主要说的):
从待排序记录中选择一个记录为哨兵,可以假设其关键字下标为m,将其余待排序记录中大于该关键字的元素移动到后面,小于改关键字的元素移动到前面,这样整个序列就变为两个表,将关键字m的记录查到两个表的分界线上,然后以m分别作为两个表的上界和下界。然后对分割后的字表同样重复上面的操作,直到最后的字表长度不超过1 为止。
实现算法一(取得的基准位置是首位,则最优时间复杂度接近折半排序o(nlgn),最坏则为o(n^2)):
void quickSort(int a[],int low, int high){ if(low<high) { pos=quickPass(a, low,high); quickSort(a, low,pos-1); quickSort(a,pos+1,high); }}int quickPass(int a[],int low,int high){ int x=a[low]; while(low<high) { while(low<high&&a[high]>=x) high--; if(low<high) { a[low]=a[high]; low++; } while(low<high&&a[low]<x) low++; if(low<high) { r[high]=r[low]; high--; } } r[low]=x; return low;}
因为很喜欢这段简短的代码,他的原作者在代码中有提到 ,我们《The programming pearl》的作者
#include <iostream>#include <math.h>using namespace std;int x[10];void swap(int m,int n){ int t; t=x[m]; x[m]=x[n]; x[n]=t;}int randint(int m,int n){ int t; t=m+rand()%(n-m+1); return t;}//快速排序的算法思想是 在输入的序列中随机选取一个元素的下表,进行一轮排序,将比这个元素小的放在该元素的左边,大的放在该元素的右边,接下来在二轮排序分别在该序列的两个子集进行,循环下去,直到只剩下一个元素。有点类似于折半排序,虽然最坏的情况需要n^2的时间,但是最好的时间是于n成正比。//《The programming pearl》's author Jon Bentlry -------the extraodinary code he had done!void quickSort(int l,int n){ int i,m; if(l>=n) return ; swap(l,randint(l, n)); //m的作用是保持比较是的同步使得m左侧的元素一定是小于m的,右侧的元素一定大于m m=l; for(i=l+1;i<=n;i++) if(x[i]<x[l]) swap(++m,i); swap(l,m); quickSort(l, m-1); quickSort(m+1, n);}int main(int argc, const char * argv[]) { // insert code here... std::cout << "Hello, World!\n"; for(int i=0;i<10;i++) cin>>x[i]; quickSort(0, 9); for(int i=0;i<10;i++) cout<<x[i]<<" "; return 0;}
简单化和模块化是互联网的基石,分布式和容错性是互联网的生命。------蒂姆·伯纳斯·李(万维网的创始人)
虽然自己对这句话理解并不是很很深刻,但是我相信,互联网这个世界是由0 1组成(除了正在研发的量子计算机的半位)的一个无限奥秘与伟大的世界,需要我们满怀热情得去探索,相信自己的未来可以在这片沃土里为后人留下个更为高效,更为优秀的世界!!!!
- 排序算法--快速排序
- 排序算法--快速排序
- 排序算法---快速排序
- 排序算法-快速排序
- 排序算法------快速排序
- 排序算法---快速排序
- 排序算法-快速排序
- 排序算法---快速排序
- 排序算法--快速排序
- 排序算法--快速排序
- 排序算法--快速排序
- 排序算法:快速排序
- 排序算法 快速排序
- 排序算法--快速排序
- 排序算法--快速排序
- 【排序算法】快速排序
- 排序算法--快速排序
- 排序算法:快速排序
- Nginx介绍和安装准备
- HDU1028整数拆分(母函数)
- 深入了解java.lang.ThreadLocal类
- 字节流(拷贝图片)
- CSS3 选择器——基本选择器
- 排序算法---快速排序
- Dota游戏匹配的所有组合
- .net框架下实现自动化测试的三种方法
- wmware安装centos
- ccf__201604-4游戏
- 【BZOJ1563】【NOI2009】诗人小G(dp+决策单调性)
- 字节流_BufferedInputStream类
- 学习淘淘商城第一课
- 工厂模式