快速排序
来源:互联网 发布:工作室源码 编辑:程序博客网 时间:2024/05/17 01:22
快速排序的思想就是以某个元素为基准,把大的放在一边,小的放在一边,则这个元素的位置就能确定了。
然后把小的那一块和大的那一块分别用同样的方法处理,类二分的递归。故复杂度o(n*log(n))
下面是实现代码
#include<cstdio>int a[10005];void quickSort(int a[],int l,int r){ int i=l,j=r,temp=a[l]; if(l<r) { while(i<j) { while(a[j]>=temp&&(i<j)) j--; a[i]=a[j]; while(a[i]<=temp&&(i<j)) i++; a[j]=a[i]; } a[i]=temp; quickSort(a,l,i-1); quickSort(a,j+1,r); }}int main(){ int n,t; scanf("%d",&t); while(t--) { scanf("%d",&n); for(int i=0;i<n;i++) scanf("%d",&a[i]); quickSort(a,0,n-1); for(int i=0;i<n-1;i++) printf("%d ",a[i]);printf("%d\n",a[n-1]); } return 0;}
0 0
- 快速排序
- 快速排序
- 快速排序
- 快速排序!
- 快速排序
- 快速排序
- 快速排序
- 快速排序
- 快速排序
- 快速排序
- 快速排序
- 快速排序
- 快速排序
- 快速排序
- 快速排序
- 快速排序
- 快速排序
- 快速排序
- 【JavaSE】关于foreach
- Linux系统密码忘记后的五种恢复方法
- How to access pixel data of an image
- 分布式系统的Raft算法
- JavaScript实现密码强度验证
- 快速排序
- Ubuntu 学习笔记
- A better understanding of java abstract class and interface
- 品茗论道说广播(Broadcast内部机制讲解)(上)
- 单向链表的基本操作
- Linked List Cycle II (Java)
- 解决懒加载问题org.hibernate.LazyInitializationException: could not initialize proxy - no Session
- 2014年总结和2015年计划
- Surface、SurfaceView、SurfaceHolder及SurfaceHolder.Callback之间的关系