快速排序非递归实现

一、排序过程

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

前面的步骤省略,当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)

相关推荐
阿维的博客日记2 小时前
Hippo4j 线程池监控平台部署手册
java·spring boot·后端
南境十里·墨染春水3 小时前
C++ 工厂模式:从入门到进阶,彻底掌握对象创建的艺术
开发语言·c++·算法
@insist1234 小时前
系统架构设计师-实时性评价、调度算法与内核架构选型
算法·架构·系统架构·软考·系统架构设计师·软件水平考试
C+++Python4 小时前
详细介绍一下Java泛型的通配符
java·windows·python
JosieBook5 小时前
【数据库】时序预测能力的分级进化:TimechoAI如何让每一类用户都能精准预见未来
java·开发语言·数据库
一生了无挂6 小时前
Java处理JSON技巧教学(从基础到高阶实战全覆盖)
java·开发语言·json
李白的天不白6 小时前
使用 SmartAdmin 进行前后端开发
java·前端
swordbob6 小时前
Spring 单例 Bean 是线程安全的吗?
java·开发语言
2601_951643777 小时前
Python第一,Java跌出前三,C语言杀回来了
java·c语言·python·编程语言排行·技术趋势