一:快速排序的特征 |
1:冒泡排序的改进
2:内部交换数据
3:分治+递归的思想
4:稳定排序
5:时间复杂度为:O(n*logn)
二:算法的整体思路 |
1:原始数据:12 11 6 87 23 8 54
2:第一次定义 key=12 以key值为参考
3:第一趟交换后大致为: 8 6 11 12 54 87 23 (把比12小的交换到左边,大的交换到右边)
4:根据以上的思想:把左边和右边的数据分别看着一组数据
左边的数据: 8 6 11
key=8
第一趟比较后可以得出:6 8 11 (比key小的放左边,大的放右边)
5:右边的数据:54 87 23
key=54
第一趟比较后可以得出:23 54 87
......................................................
按照如上的思想:递归的执行就可以得到升序的数据.
三:程序设计思想 |
1:定义key值
2:定义左边指针left、右边指针 right
3:右边->左边遍历:如果当前的值比key值小,右边和左边交换
4:左边->右边遍历:如果左边的值比key大,左边和右边交换
5:当左边的指针和右边的指针指向同一个地址,遍历终止
6:递归调用
四:代码实现如下: |
package basic.suanfa;
/**
* java版快速排序
* @author zl
*
*/
public class KuaiPaiZl {
public void qSort(int[] A,int start,int end){
//递归终止条件
if(start>=end)
return;
//设置变量
int key=A[start];//将数组的第一个值设置为Key值
//设置指针变量,从左边----向右移动
int pointRight=start;
//设置指针变量,从右边--向左移动
int pointLeft=end;
//交换数据的桥梁变量
int temp;
//开始循环
while(start!=end){
//从右边->左找一个比:key值小的数
//如果没有找到比:key小的值,指针向:右边移动
while((start!=end)&&A[pointLeft]>key){
pointLeft--;
}
//如果遍历完整个数组都未找到:就说明key值右边的值已经都比他大了
if(pointLeft==pointRight)
break;
//找到比key小的数,进行交换
temp=A[pointLeft];
A[pointLeft]=A[pointRight];
A[pointRight]=temp;
pointRight++;
//从左边->右边找一个比key大的数
while((start!=end)&&A[pointRight]<key){
pointRight++;
}
if(pointRight==pointLeft)break;
//找到比key大的数,进行交换
temp=A[pointRight];
A[pointRight]=A[pointLeft];
A[pointLeft]=temp;
pointLeft--;
}
//递归调用
qSort(A, start, pointRight-1);
qSort(A, pointRight+1, end);
}
//测试函数
public static void main(String[] args){
int[] A={15,8,7,9,3,5,6,4,7,10,41,50,27,10};
KuaiPaiZl kp=new KuaiPaiZl();
kp.qSort(A, 0, A.length-1);
System.out.println("排好序的数组为:");
for(int i=0;i<A.length;i++){
System.out.println(A[i]+"\t");
}
}
}
ps:在算法中陶醉....