快速排序非递归实现

一、排序过程

排序的思路是不变的,这里采用挖坑法,不用递归实现,用栈实现

前面的步骤省略,当left与right相遇的时候,依次将0 、4 、6、9入栈,因为栈的性质,以及入栈的顺序,弹出的时候从右往左

start为6 ,end为9再次排序即可

排序后如图

将6、7入栈

后面就是重复的过程

。。。

二、代码实现

java 复制代码
    public static void quickSort(int[] arr){
        quickNor(arr,0,arr.length - 1);
    }

    private static void quickNor(int[] arr, int start, int end) {
        Deque<Integer> deque = new ArrayDeque<>();
        int pivot = partitionHole(arr, start, end);
        if(pivot > start + 1){
            deque.push(start);
            deque.push(pivot - 1);
        }
        if(pivot < end - 1){
            deque.push(pivot + 1);
            deque.push(end);
        }
        while(!deque.isEmpty()){
            end = deque.pop();
            start = deque.pop();
            pivot = partitionHole(arr, start, end);
            if(pivot >= start + 1){
                deque.push(start);
                deque.push(pivot - 1);
            }
            if(pivot <= end - 1){
                deque.push(pivot + 1);
                deque.push(end);
            }
        }
    }

    private static int partitionHole(int[] arr, int left, int right) {
        int tmp = arr[left];
        while(left < right) {
            while(left < right && arr[right] >= tmp){
                right--;
            }
            arr[left] = arr[right];
            while(left < right && arr[left] <= tmp){
                left++;
            }
            arr[right] = arr[left];
        }
        arr[left] = tmp;
        return left;
    }

时间复杂度为 O( N *log N)

相关推荐
无限的鲜花8 小时前
反射(原创推荐)
java·开发语言
IT二叔8 小时前
Java项目部署-03-teamcity-cicd-docker镜像流水线方式部署
java·ci/cd·持续部署
一路向北he9 小时前
字节钢铁军团--“提供情境,而非控制”
java·开发语言·前端
QiLinkOS9 小时前
第三视觉理解徐玉生与他的商业活动(30)
大数据·c++·人工智能·算法·开源协议
疯狂打码的少年9 小时前
【操作系统】页面置换算法(OPT/FIFO/LRU)
算法
超级数据查看器9 小时前
超级数据查看器 v10.0 发布
java·大数据·数据库·sqlite·安卓
小O的算法实验室9 小时前
2026年CIE,优化客货协同运输:综合地铁系统的列车容量动态分配
算法
Coder_Shenshen10 小时前
西门子S7CommPlus协议鉴权算法原理与流程详解
网络·后端·算法
折哥的程序人生 · 物流技术专研10 小时前
《Java 100 天进阶之路》第50篇:阻塞队列与并发容器(2026版)
java·面试题·java进阶·blockingqueue·并发容器·集合源码·java100天进阶
ai_coder_ai11 小时前
编写自动化脚本,在自己后端服务中使用Open Api进行设备相关操作
java·运维·自动化