栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 软件开发 > 后端开发 > Java

Java快速排序

Java 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

Java快速排序

Java实现快速排序

import java.util.Arrays;

public class App {
    public static void main( String[] args ){
        int[] a = {8,3,5,9,0,1,2,4};
        quickSort(a,0,a.length-1);
        System.out.println(Arrays.toString(a));
    }
//    异或运算,不需要临时变量存储,速度较快(下面例子是二进制)
//	  异或运算的原理是相同的为0 ,不同为1
//    a=3=11
//    b=2=10
//    a=a^b=11^10=01
//    b=a^b=01^10=11
//    a=a^b=01^11=10
    public static int[] quickSort(int[] arr,int start,int end){
        int left = start,right= end;
        if (start>=end){
            return arr;
        }else{
            int startDate = arr[start];
            while (left
            	//	找到比基数startDate小的数
                while (arr[right]>=startDate && left//如果找到就交换
                    arr[left]^=arr[right];
                    arr[right]^=arr[left];
                    arr[left]^=arr[right];
                }
            }
            //将基数位置交换,如果找不到交换还是原来的数据
            arr[start]=arr[left];
            arr[left]=startDate;
            //二分思想,从找到的位置开始继续寻找,不断的缩短空间
            quickSort(arr,start,left-1);
            quickSort(arr,left+1,end);
        }
        return arr;
    }
}

数据:int[] a = {8,3,5,9,0,1,2,4};
结果:[0, 1, 2, 3, 4, 5, 8, 9]

转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/857025.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号