蓝桥杯 经典算法题 实现快速排序

题目:

题解:

快速排序其实每次不是将大区间平均分为两个子区间(这个与每次选取的基准值有关),而是每次将区间分为全大于基准值和全小于基准值两个子区间,然后又分别在子区间中再找一个基准值再分为两个子区间如此往复最终将整个数组变得有序。

#include <bits/stdc++.h>
using namespace std;
int arr[105]={0};
void quik_sort(int l,int r){if(r-l<=0)return ;else if(r-l==1){if(arr[r]<arr[l]){swap(arr[r],arr[l]);}return ;}int ind=arr[l];int x=l,y=r;while(x!=y){while(x!=y&&arr[y]>=ind)y--;swap(arr[y],arr[x]);while(x!=y&&arr[x]<ind)x++;swap(arr[y],arr[x]);}arr[x]=ind;quik_sort(l,x);quik_sort(x+1,r);
}int main(){int n;cin>>n;for(int i=0;i<n;i++)cin>>arr[i];quik_sort(0,n-1);for(int i=0;i<n;i++)cout<<arr[i]<<" ";return 0;
}

题后反思:

如何将一个数组变为两部分左半部分全部小于右半部分:

一个最简单朴素的方法是选择第一个值作为基准值并将第一个位置空出来,然后利用左右指针,当空位在左指针时用右指针找一个小于基准值的值与左指针交换,当空位在右指针时用左指针找一个大于等于基准值的值与左指针交换,知道左右指针重合然后将基准值填到这个位置上即可。

最后终止条件的判断:

第一写的是:

if(r-l=0)return ;

然后一直报错找不到原因,因为当基准值本来因该填在最后一个位置时,x和y都指向序列的末尾,然后下一次调用时范围为(nums.size()-1,nums.size())是一个不合理的区间,这种情况因该停止排序,但是程序无法识别到,所以报错。因此要根据具体实现充分考虑因该终止时的情况。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/pingmian/31643.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

TIM: A Time Interval Machine for Audio-Visual Action Recognition

标题&#xff1a;TIM&#xff1a;一种用于视听动作识别的时间间隔机器 源文链接&#xff1a;openaccess.thecvf.com/content/CVPR2024/papers/Chalk_TIM_A_Time_Interval_Machine_for_Audio-Visual_Action_Recognition_CVPR_2024_paper.pdfhttps://openaccess.thecvf.com/cont…

社区项目-项目介绍环境搭建

文章目录 1.技术选型2.原型设计1.安装AxureRP2.进行汉化3.载入元件库4.基本设计 3.元数建模1.安装元数建模软件2.新建项目3.新增一个刷题模块主题域4.新增数据表 subject_category5.新增关系图&#xff0c;将表拖过来6.新增题目标签表7.新增题目信息表8.新增单选表、多选表、判…

​Claude 3.5 最新体验:助力硕博生与科研人员高效完成论文,超越ChatGPT4o !

我是娜姐 迪娜学姐 &#xff0c;一个SCI医学期刊编辑&#xff0c;探索用AI工具提效论文写作和发表。 要不说AI领域的进展真的是日新月异&#xff0c;发展速度已经大大超过预期进度。娜姐本来在准备AI降重工具的测评文章&#xff08;最近好多小伙伴需要&#xff09;。 昨天晚上…

ECharts 词云图案例二:创意蒙版应用

ECharts 词云图案例二&#xff1a;创意蒙版应用 引言 在数据可视化领域&#xff0c;ECharts 以其强大的功能性和灵活性&#xff0c;成为开发者和设计师的首选工具之一。继上一篇关于 ECharts 词云图的详细介绍后&#xff0c;本文将探索词云图的进阶应用——使用蒙版来创造更具…

【C#上位机应用开发实战】—— UI界面设计与实践代码

在C#上位机应用开发中&#xff0c;UI界面设计是至关重要的一环。一个好的UI设计不仅可以提升应用的用户体验&#xff0c;还可以提高应用的易用性和效率。本文将介绍一些UI界面设计的实战经验和技巧。 在这个示例中&#xff0c;我们创建了一个名为MainForm的窗体类。该窗体包含了…

轮式里程计(Wheel Odometry)和惯性测量单元(IMU)的融合

轮式里程计&#xff08;Wheel Odometry&#xff09;和惯性测量单元&#xff08;IMU&#xff09;的融合通常采用某种形式的滤波技术&#xff0c;最常见的是卡尔曼滤波器&#xff08;Kalman Filter&#xff09;或其变体&#xff0c;如扩展卡尔曼滤波器&#xff08;Extended Kalma…

AI在线免费视频工具2:视频配声音;图片说话hedra

1、视频配声音 https://deepmind.google/discover/blog/generating-audio-for-video/ https://www.videotosoundeffects.com/ &#xff08;免费在线使用&#xff09; 2、图片说话在线图片生成播报hedra hedra 上传音频与图片即可合成 https://www.hedra.com/ https://www.…

Kotlin基础——优化设计模式

设计模式 使用Kotlin优化Java的设计模式写法 创建型模式 工厂方法模式 interface Computer {val cpu: String }class PC(override val cpu: String "Core") : Computer class Server(override val cpu: String "Xeon") : Computerenum class Compute…

B. Maximum Multiple Sum

time limit per test 1 second memory limit per test 256 megabytes input standard input output standard output Given an integer n&#x1d45b;, find an integer x&#x1d465; such that: 2≤x≤n2≤&#x1d465;≤&#x1d45b;.The sum of multiples of …

如何使用Windows备份轻松将数据转移到新电脑?这里有详细步骤

序言 我们都知道那种买了一台新电脑,就想直接上手的感觉。我记得在过去的日子里,要花几个小时传输我的文件,并试图复制我的设置。在当今传输数据的众多方法中,Windows备份提供了一个简单可靠的解决方案。 登录到你的Microsoft帐户 Microsoft在传输过程中使用其云存储来保…

英文字母表

目录 一 设计原型 二 后台源码 一 设计原型 二 后台源码 namespace 英文字母表 {public partial class Form1 : Form{public Form1(){InitializeComponent();}private void Form1_Load(object sender, EventArgs e){foreach (var item in panel1.Controls){if (item ! null)…

LLAVA数据集下载

LLAVA数据集下载 1. Data Data file nameSizellava_instruct_150k.json229 MBllava_instruct_80k.json229 MBconversation_58k.json126 MBdetail_23k.json20.5 MBcomplex_reasoning_77k.json79.6 MB 1.1 Pretraining Dataset The pretraining dataset used in this release…

A股3000点失守是出局还是机会?

今天的大A失守300点&#xff0c;那么A股3000点失守是出局还是机会&#xff1f; 1、今天两市低开&#xff0c;盘中一度跌破3000点&#xff0c;最低回踩到了2985点&#xff0c;盘面出现了两个罕见现象&#xff0c;意味着即将探底回升。 2、盘面出现两个罕见现象&#xff1a; 一是…

buuctf----firmware

- -一定不能再ubutu22进行,我是在18(血泪教训) binwalk安装 buuctf firmware(binwalk和firmware-mod-kit的使用)_buu firmware-CSDN博客 参考博客 指令 sudo apt-get update sudo apt-get install python3-dev python3-setuptools python3-pip zlib1g-dev libmagic-dev pi…

云计算技术高速发展,优势凸显

云计算是一种分布式计算技术&#xff0c;其特点是通过网络“云”将巨大的数据计算处理程序分解成无数个小程序&#xff0c;并通过多部服务器组成的系统进行处理和分析这些小程序&#xff0c;最后将结果返回给用户。它融合了分布式计算、效用计算、负载均衡、并行计算、网络存储…

住宅IP与普通IP的区别

在互联网连接中&#xff0c;IP地址是识别每个网络节点的关键。在众多类型的IP地址中&#xff0c;住宅IP和普通IP是两种常见的分类。本文将深入探讨住宅IP与普通IP之间的主要区别。 一、定义与来源 住宅IP指的是由互联网服务提供商&#xff08;ISP&#xff09;直接分配给家庭或…

竞赛选题 LSTM的预测算法 - 股票预测 天气预测 房价预测

0 简介 今天学长向大家介绍LSTM基础 基于LSTM的预测算法 - 股票预测 天气预测 房价预测 这是一个较为新颖的竞赛课题方向&#xff0c;学长非常推荐&#xff01; &#x1f9ff; 更多资料, 项目分享&#xff1a; https://gitee.com/dancheng-senior/postgraduate 1 基于 Ke…

理解 Q_OBJECT 宏在 Qt 中的重要性

在开始使用 Qt 框架时&#xff0c;你可能会注意到所有示例类定义的首行都包含宏 Q_OBJECT。那么&#xff0c;这个预处理宏的目的是什么&#xff1f;为什么所有的 Qt 对象都需要这个宏&#xff1f;本文将详细解答这些疑问。 Q_OBJECT 宏的作用 根据 Qt 文档&#xff0c;Q_OBJE…

k8s部署wordpress及性能优化

镜像版本&#xff1a;wordpress mysql版本&#xff1a;mysql:8.0.27 部署wordpress&#xff1a;v1 此版本包含wordpress基础服务&#xff0c;可访问&#xff0c;但是一旦pod重新创建会丢失数据&#xff0c;文章中的图片等也会丢失&#xff0c;且只又一个pod&#xff0c;性能…

高通Android 12 aapt报错问题踩坑

背景 最近因为要做多module模块&#xff0c;出现aapt报错&#xff0c;于是简单记录下&#xff0c;踩坑过程。 1、我一开始项目中三个module&#xff0c;然后在build.gradle设置androidApplication plugins {alias(libs.plugins.androidApplication) }2、运行完之后都是报下面…