快速排序非递归实现

一、排序过程

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

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

相关推荐
wuweijianlove2 小时前
算法性能的渐近与非渐近行为对比的技术4
算法
一定要AK2 小时前
Spring 入门核心笔记
java·笔记·spring
A__tao2 小时前
Elasticsearch Mapping 一键生成 Java 实体类(支持嵌套 + 自动过滤注释)
java·python·elasticsearch
_dindong2 小时前
cf1091div2 C.Grid Covering(数论)
c++·算法
AI成长日志2 小时前
【Agentic RL】1.1 什么是Agentic RL:从传统RL到智能体学习
人工智能·学习·算法
KevinCyao2 小时前
java视频短信接口怎么调用?SpringBoot集成视频短信及回调处理Demo
java·spring boot·音视频
迷藏4942 小时前
**发散创新:基于Rust实现的开源合规权限管理框架设计与实践**在现代软件架构中,**权限控制(RBAC)** 已成为保障
java·开发语言·python·rust·开源
黎阳之光2 小时前
黎阳之光:视频孪生领跑者,铸就中国数字科技全球竞争力
大数据·人工智能·算法·安全·数字孪生
skywalker_112 小时前
力扣hot100-3(最长连续序列),4(移动零)
数据结构·算法·leetcode
6Hzlia2 小时前
【Hot 100 刷题计划】 LeetCode 17. 电话号码的字母组合 | C++ 回溯算法经典模板
c++·算法·leetcode