快排

哈哈,刚刚注册,纪念第一篇 

前几天写了快排,发现了很多问题

      public static void kuaipai(int arr[],int low,int high){
		if(low<high){
			int i = low;
			int j = high;
			int x = arr[i];
			while(i<j){
				while(i < j && arr[j]>=x){//如果右侧比x大,j一直--
					j--;
				}
				if(i<j){
					arr[i] = arr[j];
				}
				while(i < j && arr[i]<x){//如果左侧比x小,i一直++
					i++;
				}
				if(i<j){
					arr[j] = arr[i];
				}
			}
			arr[j] = x;//此时i=j
			kuaipai(arr,low,i-1); //此时x(arr[i])已经固定位置,再递归,左右分别重复排
			kuaipai(arr,i+1,high);  
		}
	}


01234
29567-898
567-898
-856798
......

首先,快排,先取出数组的第一个数作为比较数,此刻可以将第一个位置看做空的,再将数组第一个和最后一个位置标记,然后先从后往前依次与取出的比较数进行比较,按照从小到大的顺序排列,所以,从后往前找小于比较数的数,如果后面的数大于比较数则一直往前找也就是最后一个位置的标记--,直到2个标记相等停止找,当后面的数相比比较数小时,将此数填在空位,只要数组改变,就要换方向查找,接下来从前往后找,同理于从后往前,当2个标记相等时,当前下标下也是空的,将比较数填在此位置,这个时候比较数的位置确定,前面均是小于比较数的数,后面均是大于比较数的数。接下来就使用递归继续排序,比较数前和后分别看做2个数组继续进行上述比较。

注意的是,arr[j]>=x和arr[i]<x,>=是一组的,如果arr[j]>x和arr[i]<=x则排序失败。

愿君学长松,慎勿作桃李

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值