排序:非递归的快排

目录

非递归的快排:

代码分析:

代码演示:


非递归的快排:

众所周知,递归变成非递归,而如果还想具有递归的功能,那么递归的那部分则需要变成循环来实现。

而再我们的排序中,我们可以采取栈的方式,用入栈、出栈、栈是否为空来完成递归的部分。

如图所示,这是序列分割时的图片,我们可以将一段序列的最左端下标和最右端下标丢入栈内,随后赋予临时变量之后出栈,然后利用临时变量组成的区间将序列进行一次的快排

快排结束返回key值,再根据key值继续划分序列,并且再度传入序列的最左端和最右端下标入栈随后立马赋予临时变量然后出栈,这样用入栈和出栈来控制循环。

代码分析:

这串代码的本质是利用了栈的后进先出的原理,以及二叉树后序遍历的原理。

当一个元素入栈后立马出栈,只要序列不是只剩下一个元素,那么它会带入两个元素入栈。

而这入栈,同时也是一种遍历,如下代码所示,通过计算我们得知最开始是数组的前端后入栈,但是是先出栈,出栈后他会带着四个元素入栈,而后端的两个下标则是被压倒了栈底,直到前端不能再入栈了后端才会出栈并且带四个元素入栈。

代码演示:


相关推荐
牛马大师兄4 分钟前
数据结构复习 | 什么是数据结构?
数据结构
YuTaoShao7 分钟前
【LeetCode 每日一题】2053. 数组中第 K 个独一无二的字符串
算法·leetcode·职场和发展
朔北之忘 Clancy1 小时前
第二章 分支结构程序设计(3)
c++·算法·青少年编程·竞赛·教材·考级·讲义
想逃离铁厂的老铁1 小时前
Day42 >> 188、买卖股票的最佳时机IV + 309.最佳买卖股票时机含冷冻期 + 714.买卖股票的最佳时机含手续费
算法·leetcode·职场和发展
wu_asia1 小时前
方阵对角线元素乘积计算
数据结构·算法
想逃离铁厂的老铁1 小时前
Day43 >> 300.最长递增子序列 + 674. 最长连续递增序列+ 718. 最长重复子数组
数据结构·算法
Yzzz-F1 小时前
P6648 [CCC 2019] Triangle: The Data Structure [st表]
算法
LateFrames2 小时前
泰勒级数:从 “单点” 到 “理论与实践的鸿沟”
学习·算法
武帝为此2 小时前
【RC4加密算法介绍】
网络·python·算法
宵时待雨2 小时前
数据结构(初阶)笔记归纳4:单链表的实现
c语言·开发语言·数据结构·笔记·算法