C++ 中快排的递归和非递归实现
发布时间 - 2026-01-11 01:53:24 点击率:次快排的递归
void quickSort1(int* root,int low,int high)
{
int pat=root[low];
if(low<high)
{
int i=low,j=high;
while(i<j)
{
while(i<j&&root[j]>pat)
j--;
root[i]=root[j];
while(i<j&&root[i]<pat)
i++;
root[j]=root[i];
}
root[i]=pat;
quickSort1(root,low,i-1);
quickSort1(root,i+1,high);
}
}
快排的非递归
int partion(int* root,int low,int high)
{
int part=root[low];
while(low<high)
{
while(low<high&&root[high]>part) high--;
root[low]=root[high];
while(low<high&&root[low]<part) low++;
root[high]=root[low];
}
root[low]=part;
return low;
}
void quickSort2(int* root,int low,int high)
{
stack<int> st;
int k;
if(low<high)
{
st.push(low);
st.push(high);
while(!st.empty())
{
int j=st.top();st.pop();
int i=st.top();st.pop();
k=partion(root,i,j);
if(i<k-1)
{
st.push(i);
st.push(k-1);
}
if(k+1<j)
{
st.push(k+1);
st.push(j);
}
}
}
}
int main()
{
int a[8]={4,2,6,7,9,5,1,3};
quickSort1(a,0,7);
//quickSort2(a,0,7);
int i;
for(i=0;i<8;i++)
cout<<a[i]<<" ";
cout<<endl;
getchar();
return 0;
}
感谢阅读,希望能帮助到大家,谢谢大家对本站的支持!
# C++
# 中快排的递归和非递归
# 数据结构中快排的递归和非递归实现
# C++:函数对象
# STL提供的函数对象
# 函数适配器详解
# C++在成员函数中使用STL的find_if函数实例
# C++归并排序算法详解
# C++编程归并排序算法实现示例
# C++实现归并排序
# C++STL函数和排序算法的快排以及归并排序详解
# 递归
# 希望能
# 谢谢大家
# root
# int
# high
# amp
# lt
# pat
# pre
# br
# strong
# class
# void
# java
# brush
# gt
# pop
# top
# empty
相关栏目:
【
网站优化151355 】
【
网络推广146373 】
【
网络技术251813 】
【
AI营销90571 】
相关推荐:
深圳防火门网站制作公司,深圳中天明防火门怎么编码?
猎豹浏览器开发者工具怎么打开 猎豹浏览器F12调试工具使用【前端必备】
个人网站制作流程图片大全,个人网站如何注销?
如何构建满足综合性能需求的优质建站方案?
IOS倒计时设置UIButton标题title的抖动问题
如何在万网自助建站中设置域名及备案?
Laravel PHP版本要求一览_Laravel各版本环境要求对照
网站优化排名时,需要考虑哪些问题呢?
原生JS获取元素集合的子元素宽度实例
html5源代码发行怎么设置权限_访问权限控制方法与实践【指南】
详解jQuery中基本的动画方法
Laravel如何实现全文搜索功能?(Scout和Algolia示例)
Laravel Blade模板引擎语法_Laravel Blade布局继承用法
简历在线制作网站免费版,如何创建个人简历?
JavaScript如何操作视频_媒体API怎么控制播放
Laravel项目如何进行性能优化_Laravel应用性能分析与优化技巧大全
Android利用动画实现背景逐渐变暗
如何快速查询网站的真实建站时间?
如何基于PHP生成高效IDC网络公司建站源码?
郑州企业网站制作公司,郑州招聘网站有哪些?
Laravel如何集成第三方登录_Laravel Socialite实现微信QQ微博登录
如何在万网自助建站平台快速创建网站?
详解Android图表 MPAndroidChart折线图
如何用西部建站助手快速创建专业网站?
Swift开发中switch语句值绑定模式
Windows10如何删除恢复分区_Win10 Diskpart命令强制删除分区
Swift中switch语句区间和元组模式匹配
javascript基本数据类型及类型检测常用方法小结
大连 网站制作,大连天途有线官网?
Laravel怎么多语言本地化设置_Laravel语言包翻译与Locale动态切换【手册】
移动端手机网站制作软件,掌上时代,移动端网站的谷歌SEO该如何做?
怎么用AI帮你为初创公司进行市场定位分析?
悟空浏览器如何设置小说背景色_悟空浏览器背景色设置【方法】
如何获取免费开源的自助建站系统源码?
韩国代理服务器如何选?解析IP设置技巧与跨境访问优化指南
Laravel如何实现RSS订阅源功能_Laravel动态生成网站XML格式订阅内容【教程】
如何用搬瓦工VPS快速搭建个人网站?
Laravel如何配置任务调度?(Cron Job示例)
简历没回改:利用AI润色让你的文字更专业
Laravel如何创建和注册中间件_Laravel中间件编写与应用流程
1688铺货到淘宝怎么操作 1688一键铺货到自己店铺详细步骤
laravel怎么实现图片的压缩和裁剪_laravel图片压缩与裁剪方法
高性能网站服务器配置指南:安全稳定与高效建站核心方案
如何有效防御Web建站篡改攻击?
如何在服务器上配置二级域名建站?
EditPlus中的正则表达式 实战(4)
Laravel怎么返回JSON格式数据_Laravel API资源Response响应格式化【技巧】
C#如何调用原生C++ COM对象详解
如何在Windows环境下新建FTP站点并设置权限?
如何自定义safari浏览器工具栏?个性化设置safari浏览器界面教程【技巧】

