快速排序非递归实现

一、排序过程

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

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

相关推荐
二哈赛车手1 天前
新人笔记---ApiFox的一些常见使用出错
java·笔记·spring
吃好睡好便好1 天前
在Matlab中绘制横直方图
开发语言·学习·算法·matlab
栗子~~1 天前
JAVA - 二层缓存设计(本地缓冲+redis缓冲+广播所有本地缓冲失效) demo
java·redis·缓存
YDS8291 天前
DeepSeek RAG&MCP + Agent智能体项目 —— RAG知识库的搭建和接口实现
java·ai·springboot·agent·rag·deepseek
仰泳之鹅1 天前
【C语言】自定义数据类型2——联合体与枚举
c语言·开发语言·算法
未若君雅裁1 天前
MyBatis 一级缓存、二级缓存与清理机制
java·缓存·mybatis
AI人工智能+电脑小能手1 天前
【大白话说Java面试题 第65题】【JVM篇】第25题:谈谈对 OOM 的认识
java·开发语言·jvm
阿维的博客日记1 天前
Nacos 为什么能让配置动态生效?(涉及 @RefreshScope 注解)
java·spring
雨辰AI1 天前
SpringBoot3 + 人大金仓读写分离 + 分库分表 + 集群高可用 全栈实战
java·数据库·mysql·政务
x_yeyue1 天前
三角形数
笔记·算法·数论·组合数学