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

快排代码实现

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

快排代码实现

快排代码实现如下:

public class FastSortExer1 {
    public static void main(String[] args) {
        int[] numbers = {4, 1, 2, 5, 7, 4, 8, 3, 8, 4, 5, 9, 7, 3, 1};
        fastSort(numbers, 0, numbers.length - 1);
        System.out.println(Arrays.toString(numbers));
    }

    
    private static void fastSort(int[] numbers, int left, int right) {
        //递归出口,当起始位置大于结束位置,开始结束递归
        if (left >= right) return;

        //记录起始位置
        int start = left;
        //记录结束位置
        int end = right;
        //设定其实位置的元素作为目标元素,寻找该元素的正确位置
        int target = numbers[left];

        //开始寻找目标元素正确位置
        while (start != end) {
            //从后往前开始寻找,若发现比目标元素小的元素,将其放置start标记索引处
            while (start < end && numbers[end] >= target) end--;
            numbers[start] = numbers[end];

            //从前往后寻找,若发现比目标元素大的元素,将其放置end标记索引处
            while (start < end && numbers[start] <= target) start++;
            numbers[end] = numbers[start];
        }

        //寻找结束后,start标记与end标记的索引处即为目标元素的正确位置
        numbers[start] = target;

        //分治思想,将目标元素左边与右边的元素分别进行排序
        fastSort(numbers, left, start - 1);
        fastSort(numbers, start + 1, right);


    }

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

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

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