快排的非递归实现

2023-11-14

快排的非递归

这里我们需要借助数据结构的栈模拟快排的递归过程(栈先进后出)

实现思想:

1.先将需要排序的区间入到栈中
2.栈不为空时,将需要排序区间读取出来,进行单趟排序,获得了key位置,判断key左右区间是否存在,若存在,将左右下标数据入栈,若不存在(表示区间里只有一个数或者没有数),不做处理。
3.重复此过程,直到栈为空时,排序完成。

这里三数取中是优化快排,单趟排序推荐前后指针法,单趟排序详情可看冒泡与快排那篇文章。

int MidIndex(int* a, int left, int right)
{
    int mid = left + (right - left) / 2;
    if (a[mid] < a[left])
    {
        if (a[mid] > a[right])
            return mid;
        else if (a[right] < a[left])
            return right;
        else
            return left;
    }
    else
    {
        if (a[left] > a[right])
            return left;
        else if (a[mid] > a[right])
            return right;
        else
            return mid;
    }
}

void Swap(int* a, int* b)
{
    int tmp = *a;
    *a = *b;
    *b = tmp;
}
int SingleSort(int* a, int begin, int end)
{
    int mid = MidIndex(a, begin, end);
    Swap(&a[mid], &a[begin]);
    int key = begin;
    int prev = begin;
    int cur = begin + 1;
    while (cur <= end)
    {
        if (a[cur] < a[key] && ++prev != cur)
        {
            Swap(&a[cur], &a[prev]);
        }
        cur++;
    }
    Swap(&a[prev], &a[key]);
    return prev;
}

//入数据记得先入左边,再入右边,栈先进后出的性质
void QuickSortNonR(int* a, int left, int right)//借助栈结构模拟递归过程
{
    stack<int> st;
    st.push(left);
    st.push(right);//先将需排序区间入栈
    while (!st.empty())//判断栈中是否还有需排序区间
    {
        int end = st.top();
        st.pop();
        int begin = st.top();
        st.pop();
        int keyi = SingleSort(a, begin, end);
        if (keyi + 1 < end)//表示keyi右边区间存在,入栈
        {
            st.push(keyi + 1);//先入左边下标
            st.push(end);//在入右边下标
        }
        if (keyi - 1 > begin)//表示keyi左边区间存在,入栈
        {
            st.push(begin);//先入左边下标
            st.push(keyi - 1);//在入右边下标
        }
    }
}

 调用

int main()
{
    int a[] = { 1,21,7,27,9,2,0,5,8,3,11,15,17,19};
    int len = sizeof(a) / sizeof(int);
    QuickSortNonR(a, 0, len - 1);
    for (int i = 0; i < len; i++)
    {
        cout << a[i] << " ";
    }
    return 0;

程序结果 

 

本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)

快排的非递归实现 的相关文章

  • HCIP2------路由器、交换机的转发原理

    一 路由器 1 路由器产生的原因 对于普通用户来说 主机A与主机B通信需要通过路由器 从而构成简单的局域网 局域网内的计算机要和外面的计算机进行通信 要把请求提交给路由器的以太口 进而发展成为广域网 同时需要有一种方法来判断从源主机到达目的

随机推荐

  • Lattic Diamond软件安装不成功问题

    安装过程可以远程操作 但安装完成后不能通过远程来打开软件应用程序 一定要在本地电脑上打开使用 否则lisence中的MAC地址会不匹配
  • ScrollView默认位置不是最顶部

    场景描述 在scrollview中套用了一个recycleview 发现 recycleview上面的部分TextView不能被显示 直接显示的是recycleview的底部 分析原因 在Activity计算窗口的高度时 是在listvie
  • 在Excel中根据条件查找匹配多个值

    在Excel中根据条件查找匹配多个值 vlookup只能匹配第一个值 之前在深圳的时候就被问过这个问题 今天又遇到同事在问 索性记录在此 如下图 根据E列的值 在A列中查找对应的数据 输出匹配行上B列的值 依次填入到F G H 列 公式拆解
  • idea 配置maven常见问题

    1 在applicationContext dao xml中配置数据源时提示 cannot resolve property key 解决 在Facets中移除spring 重新添加一次 将xml引入 2 maven 下载的依赖库Depen
  • 腾讯云服务器标准型S5、S4、S3、S2区别及怎么选择?

    腾讯云标准型服务器包括S2 S3 S4实例 这些实例都是标准型服务器 那么S2 S3 S4 S5区别在哪里呢 在这一块选择的时候新手会有很多犹豫 看上去型号都差不多 配置里面很多参数也看不懂 到底怎么选呢 接下来带大家去看看详细情况 腾讯云
  • VS code 插件配置手册

    点击上方 小白学视觉 选择加 星标 或 置顶 重磅干货 第一时间送达 VS code 插件配置手册 C C Tools插件 C C 支持安装库文件的配置GDB本地调试配置GDB远程调试配置Remote VSCode插件 远程编辑文件安装环境
  • VCPKG 包下载失败解决思路

    vcpkg经常会遇到资源无法访问 可能是域名解析出了问题 我们只需要将域名解析后的ip地址添加到hosts文件列表中可解决此问题 如 185 199 108 133 raw githubusercontent com 在此之前可先通过终端p
  • spring-boot-starter家族成员简介

    应用程序starters 以下应用程序starters是Spring Boot在org springframework boot组下提供的 springboot使用指南https docs spring io spring boot doc
  • Transforms的使用

    Transforms是常用的图像预处理方法 提高泛化能力 其实是一个py文件 其中包含了totensor 将数据类型转换成tensor类型 resize等工具 tensor数据类型 通过Transforms totensor去看两个问题 1
  • Linux 的 anaconda 虚拟环境下安装指定的 cuda、cudnn、pytorch

    感悟 首先 anaconda 的虚拟环境真香 开辟一个新的虚拟环境 很多环境 版本不兼容的问题都不复存在 尤其对复现别人代码的同学很有用 条件 只要安装的版本不超过自己机器的硬件条件 那么就可以安装 步骤 1 确定安装的 cuda 版本 在
  • springBoot+scheduling实现多任务动态定时任务

    使用spring自带的scheduling定时调度任务相当于轻量级的Quartz 但是不支持分布式 若要实现分布式定时任务就得使用Quartz了 第一步 在入口类中声明定时任务 import org springframework boot
  • java中比较两个map是否相同

    结论 对于所有继承于AbstractMap的map类 基本上jdk中的map都继承了 直接使用Map equals 即可 源码解析 AbstractMap重写了equals方法 保证对两个相同内容的map调用equals比较结果为真 源码如
  • opencv之人脸检测项目实战(二)

    自我介绍 目录 一 人脸检测整体架构 1 1 什么是人脸检测 1 2 人脸检测的应用场景 1 3 人脸检测核心架构 二 人脸检测实现技术储备 2 1 NDK开发的原理 2 2 什么是JNI 2 3 OpenCV架构体系 三 人脸识别项目实战
  • vue-cli打包

    创建vue config js文件 设置不同模式的打包入口 把main js文件删除 创建main prod js和main dev js module exports chainWebpack config gt 判断当前的编译模式 设置
  • 【python】统计代码行数

    背景 写了一堆 cs文件 想看看一共写了多少行 代码 import os import chardet Check if a file has the given extension def has extension file exten
  • 模型转换、模型压缩、模型加速工具汇总

    目录 一 场景需求解读 二 模型转化工具汇总 1 模型转换工具的作用 2 模型转换工具简介 1 MMdnn 2 ONNX 3 X2Paddle 三 模型压缩和加速工具汇总 1 模型压缩加速工具的作用 2 模型压缩加速工具简介 1 Pocke
  • 计算方法--解线性方程组的迭代法

    文章目录 雅可比迭代法 Jacobi 迭代公式的矩阵形式 编程计算公式 迭代思路 高斯 赛德尔迭代法 Gauss Seidel 迭代法的收敛性 迭代法收敛性基本定义 收敛速度 迭代法充分条件1 迭代法充分条件2 迭代法其他收敛条件 JOR迭
  • 如何使UI自动化项目成功?

    目标 错误的目标 追求一些错误的目标 会使自动化测试走向失败 1 替代手工测试 自动化无法替代手工测试 只能作为辅助手段 在如图的第二象限起作用 2 高比率的UI测试覆盖率 不是覆盖率越高越好 由测试金字塔来看 底端占比越高 自动化效率越好
  • 学前端开发适用于移动端常见的问题

    常见问题1 移动端如何定义字体font family三大手机系统的字体 ios 系统默认中文字体是Heiti SC默认英文字体是Helvetica默认数字字体是HelveticaNeue无微软雅黑字体android 系统默认中文字体是Dro
  • 快排的非递归实现

    快排的非递归 这里我们需要借助数据结构的栈模拟快排的递归过程 栈先进后出 实现思想 1 先将需要排序的区间入到栈中 2 栈不为空时 将需要排序区间读取出来 进行单趟排序 获得了key位置 判断key左右区间是否存在 若存在 将左右下标数据入