当前位置: 首页 > news >正文

【算法】快速排序

目录

核心思想:

过程:

演示:

第一趟:

第二趟:

 代码:


核心思想:

从待排序列中取一个元素作为中心,所有比它小或相等的元素一律放在前面,

所有比它大的元素放在后面,形成左右两个表,然后在对各个子表重新选择

中心元素,并按此规则调整,直到每一个子表的元素只剩最后一个,此时

便成为有序序列了。

过程:

设置两个指针 i 和 j ,分别从左往右找比基准元素大的和从右往左找比基准元素小

的元素

演示:

待排序序列:( 2   8   7  1   3    5     6     4)

选则关键字:   4      (以4为基准)

第一趟:

2和4进行比较,2小于4 不交换位置,指针 i 向右移动一位

8和4比较,8大于4,交换位置

此时,基准元素4左边元素都比4小,移动  j 指针向左移动一位

6与4比较,6大于4,不交换位置,指针 j 向左移动一位

 

5与4比较,5大于4,位置不交换,指针 j 向左移动一位

3与4比较,3小于4,交换位置

此时,基准元素4的右边元素都比4大,移动 i 指针向右移动一位

 7和4比较,7大于4,交换位置

 此时,基准元素4左边元素小于4,移动 j 指针向左移动一位

1与4比较,1小于4,交换位置

此时,基准元素4的左边元素都比4小,右边元素都比4大,至此第一趟排序结束

第二趟:

此时划分两个部分,第一部分(2 3 1)  第二部分 (7 5 6 8)

分别按照上述方法进行排列

最后结果 1 2 3  4   5   6   7   8  9 

 代码:

#include <stdio.h>// 定义数组长度
#define N 10// 快速排序函数
void quick_sort(int arr[], int left, int right)
{if (left < right) {int i = left, j = right, pivot = arr[left];while (i < j) {while (i < j && arr[j] >= pivot) {j--;}if (i < j) {arr[i++] = arr[j];}while (i < j && arr[i] <= pivot) {i++;}if (i < j) {arr[j--] = arr[i];}}arr[i] = pivot;quick_sort(arr, left, i - 1);quick_sort(arr, i + 1, right);}
}// 主函数
int main()
{int arr[N] = {5, 9, 3, 6, 1, 8, 2, 7, 4, 0};quick_sort(arr, 0, N - 1);for (int i = 0; i < N; i++) {printf("%d ", arr[i]);}return 0;
}

 

 

 

 

 

 

 

 

 

相关文章:

【算法】快速排序

目录 核心思想&#xff1a; 过程&#xff1a; 演示&#xff1a; 第一趟&#xff1a; 第二趟&#xff1a; 代码&#xff1a; 核心思想&#xff1a; 从待排序列中取一个元素作为中心&#xff0c;所有比它小或相等的元素一律放在前面&#xff0c; 所有比它大的元素放在后面&…...

【移动端网页布局】流式布局案例 ③ ( 实现搜索栏功能 | 伪元素选择器 | 子绝父相 | 外边距塌陷处理 | 二倍精灵图处理方案 )

文章目录 一、搜索栏样式及核心要点1、实现效果2、自动伸缩搜索栏实现3、搜索栏父容器设置4、搜索栏左右两侧的按钮盒子5、搜索栏盒子6、二倍精灵图处理方案 二、完整代码示例1、HTML 标签结构2、CSS 样式3、展示效果 一、搜索栏样式及核心要点 1、实现效果 上一篇博客中 , 完成…...

【C++修炼之路】30.可变参数模板包装器

每一个不曾起舞的日子都是对生命的辜负 C11之可变参数模板&&包装器 前言一.可变参数模板的首次登场二.参数包展开2.1 递归函数方式展开参数包2.2 逗号表达式展开参数包 三.容器的emplace方法四.包装器4.1 什么是function4.2 function包装器的作用4.3 function的实际用途…...

Linux防火墙之firewalld基础

一、firewalld概述 firewalld防火墙是Centos7系统默认的防火墙管理工具&#xff0c;取代了之前的iptables防火墙&#xff0c;也是工作在网络层&#xff0c;属于包过滤防火墙。 firewalld和iptables都是用来管理防火墙的工具&#xff08;属于用户态&#xff09;来定义防火墙的…...

GitLab CI/CD

CI/CD 简介 CI/CD 简单来说就是可以自动化编译、测试、打包我们的代码。 GitLab CICD的使用 首先需要安装gitlab-runner。 在GitLab 中&#xff0c;runners 是运行 CI/CD 作业的代理。我们的对代码的作业都是在runner上去执行的。我们可以在本地、服务器、等任意一个联网设…...

PHP复习资料(未完待续)

&#xff08;未完待续&#xff0c;请持续关注此板块&#xff09; 【计科三四】雪课堂PHP期末模拟题&#xff1a;https://ks.wjx.top/vm/tUAmjxq.aspx# 【计科一二】PHP第一章练习题 https://ks.wjx.top/vm/QnjHad4.aspx# 【计科一二】PHP第二章练习题 https://ks.wjx.top/vm/h2…...

【python】pytorch包(第二章)API使用与介绍

1> nn.Module &#xff08;用于构建模型的底层逻辑&#xff09; 介绍 nn.Module 是 torch.nn 中的一个类&#xff0c;是pytorch中自定义网络的基类 __init__需要调用super方法&#xff0c;继承父类属性和方法forward方法必须实现&#xff0c;用来定义网络的向前计算的过程…...

Linux驱动基础(SR501人体感应模块)

文章目录 前言一、SR501模块介绍二、设备树编写三、驱动编写1.确定主设备号2.编写file_operations结构体3.注册file_operations结构体4.出口函数编写5.probe函数和remove函数编写6.中断编写7.测试程序编写8.全部驱动程序 总结 前言 本篇文章将给大家介绍一下SR501驱动程序的编…...

Android Studio Flamingo (火烈鸟) 升级踩坑记录

由于想要验证Compose最新的debug特性&#xff0c;而我目前使用的版本&#xff08;Dolphin 小海豚&#xff09;不支持&#xff0c;查看官网说明需要最新版本&#xff0c;所以不得已进行了一下Android Studio版本升级&#xff0c;过程中遇到一些问题&#xff0c;本文仅做记录。&a…...

【JAVA凝气】异常篇

哈喽~大家好呀&#xff0c;这篇来看看JAVA异常篇。 目录 一、前言 二、Exception 异常 1、Java 的非检查性异常 2、Java 检查性异常类 三、Error 错误 四、捕获异常 五、多重捕获块 六、throws/throw 关键字 七、自定义异常类 八、图书推荐 一、前言 异常是程序中的一…...

C++中的函数模板

目录 1. 什么是函数模板&#xff1f; 2. 如何定义函数模板&#xff1f; 3. 如何使用函数模板&#xff1f; 4. 函数模板与函数重载的区别是什么&#xff1f; 5. 函数模板与类模板有何异同点&#xff1f; 1. 什么是函数模板&#xff1f; - 函数模板是一种通用的函数描述&…...

MapReduce【Shuffle-Combiner】

概述 Conbiner在MapReduce的Shuffle阶段起作用&#xff0c;它负责局部数据的聚合&#xff0c;我们可以看到&#xff0c;对于大数据量&#xff0c;如果没有Combiner&#xff0c;将会在磁盘上写入多个文件等待ReduceTask来拉取&#xff0c;但是如果有Combiner组件&#xff0c;我们…...

postman接口自动化测试

Postman除了前面介绍的一些功能&#xff0c;还有其他一些小功能在日常接口测试或许用得上。今天&#xff0c;我们就来盘点一下&#xff0c;如下所示&#xff1a; 1.数据驱动     想要批量执行接口用例&#xff0c;我们一般会将对应的接口用例放在同一个Collection中&#xf…...

历经70+场面试,我发现了大厂面试的套路都是···

今年的金三银四刚刚过去&#xff0c;我又想起了我在去年春招时面试了50余家&#xff0c;加上暑期实习面试了20余家&#xff0c;加起来也面试了70余场的面试场景了。 基本把国内有名的互联网公司都面了一遍&#xff0c;不敢说自己的面试经验很丰富&#xff0c;但也是不差的。 …...

可视区域兼容性问题的思考及方法封装

今日在复习可视化尺寸获取时突发奇想&#xff0c;为什么要在怪异模式下使用document.body.clientWidth&#xff0c;在标准模式下使用document.documentElement.clientWidth&#xff1f;以及是否在IE8及以下的版本中其中一个获取方式将返回undefined或0。  出于该问题的思考&am…...

安全工具 | CMSeeK [指纹识别]

0x00 免责声明 本文仅限于学习讨论与技术知识的分享&#xff0c;不得违反当地国家的法律法规。对于传播、利用文章中提供的信息而造成的任何直接或者间接的后果及损失&#xff0c;均由使用者本人负责&#xff0c;本文作者不为此承担任何责任&#xff0c;一旦造成后果请自行承担…...

Android新logcat使用技巧

Android新logcat使用技巧 logcat新UI出现后&#xff0c;我常困惑于怎么过滤log&#xff0c;和以前的UI差异比较大&#xff0c;新UI界面结构如下&#xff1a; 这个新的 logcat 的问题是如何过滤信息并不是很明显。 获取应用的日志信息 要获取我们当前调试应用的日志信息&…...

使用Makefile笔记总结

文章目录 一、简单了解Makefile1.1 Makefile示例1.2 基本规则1.3 make是如何工作的1.4 使用变量1.5 make自动推导 二、变量2.1 变量的定义和引用2.2 变量的两种高级用法2.3 override 和 define 关键字2.4 环境变量与目标变量2.5 自动变量 三、Makefile规则3.1 通配符3.2 目标依…...

npm下载依赖项目跑不起来--解决方案

code ERESOLVE npm ERR! ERESOLVE unable to resolve dependency tree npm ERR! npm ERR! While resolving: vue-element-admin4.4.0 npm ERR! Found: webpack4.46.0 npm ERR! node_modules/webpack npm ERR! webpack“^4.23.0” from the root project npm ERR! npm ERR! Coul…...

SolVES模型生态系统服务功能社会价值评估

查看原文>>>SolVES 模型生态系统服务功能社会价值评估&#xff08;基于多源环境QGIS、PostgreSQL、ArcGIS、Maxent、R语言&#xff09; 目录 第一章、理论基础与研究热点 第二章、SolVES 4.0 模型运行环境配置 第三章、SolVES 4.0 模型运行 第四章、数据获取与入…...

SDMatte助力电商应用:批量生成商品透明背景主图实战

SDMatte助力电商应用&#xff1a;批量生成商品透明背景主图实战 1. 电商行业的商品图处理痛点 电商商家每天都要处理大量商品图片&#xff0c;其中最常见也最耗时的任务之一就是抠图。无论是上新商品还是优化现有商品展示&#xff0c;都需要将商品从原始背景中分离出来&#…...

Nunchaku FLUX.1 CustomV3实战:用简单描述生成赛博朋克、水墨风等多样作品

Nunchaku FLUX.1 CustomV3实战&#xff1a;用简单描述生成赛博朋克、水墨风等多样作品 你是否曾经想象过&#xff0c;只需输入一句话&#xff0c;就能让AI为你创作出风格各异的精美画作&#xff1f;今天我们要深入探索的Nunchaku FLUX.1 CustomV3镜像&#xff0c;正是这样一个…...

程序员转型AI:大模型时代算法工程师的三种发展路径

程序员转型AI&#xff1a;大模型时代算法工程师的三种发展路径时代变了&#xff1a;从"稀缺资源"到"工业级生产资料" 在没有大模型的时代&#xff08;其实也就两三年前&#xff09;&#xff0c;算法工程师是干嘛的&#xff1f;那时候&#xff0c;模型是&qu…...

告别手动录入!用Zotero+Jasminum插件自动抓取知网元数据,高效管理学位论文PDF

告别手动录入&#xff01;用ZoteroJasminum插件自动抓取知网元数据&#xff0c;高效管理学位论文PDF 每次下载几十篇学位论文后&#xff0c;最头疼的莫过于手动录入文献信息——作者、标题、导师、学校、年份...这些字段一个个复制粘贴&#xff0c;不仅耗时费力&#xff0c;还…...

SEO关键词优化和广告投放的关系是什么

SEO关键词优化和广告投放的关系是什么 在当今数字营销的世界里&#xff0c;SEO关键词优化和广告投放是两个不可或缺的组成部分。它们之间的关系不仅仅是独立存在&#xff0c;而是相辅相成&#xff0c;共同为企业的网络营销目标提供支持。本文将详细探讨SEO关键词优化和广告投放…...

国内AI招聘系统,如何才能选对系统的真实能力?

你有没有过这样的经历&#xff1a;看了一堆 AI 招聘系统的宣传&#xff0c;吹得天花乱坠&#xff0c;又是 “智能筛选” 又是 “AI 面试”&#xff0c;结果买回去发现根本不是那么回事 —— 简历筛选还是靠关键词匹配&#xff0c;AI 面试就是把预设问题念一遍&#xff0c;候选人…...

零基础玩转OpenClaw:SecGPT-14B安全问答机器人搭建指南

零基础玩转OpenClaw&#xff1a;SecGPT-14B安全问答机器人搭建指南 1. 为什么选择OpenClawSecGPT-14B组合 去年我在处理公司内网安全审计时&#xff0c;发现很多基础安全问题反复出现。当时就想&#xff1a;如果能有个24小时在线的安全助手&#xff0c;随时解答团队疑问该多好…...

PyTorch-OpCounter终极指南:10个常见问题快速解决模型计算量统计难题

PyTorch-OpCounter终极指南&#xff1a;10个常见问题快速解决模型计算量统计难题 【免费下载链接】pytorch-OpCounter Count the MACs / FLOPs of your PyTorch model. 项目地址: https://gitcode.com/gh_mirrors/py/pytorch-OpCounter PyTorch-OpCounter&#xff08;TH…...

Android-Password-Store自动填充功能详解:让密码自动填写变得简单高效

Android-Password-Store自动填充功能详解&#xff1a;让密码自动填写变得简单高效 【免费下载链接】Android-Password-Store Android application compatible with ZX2C4s Pass command line application 项目地址: https://gitcode.com/gh_mirrors/an/Android-Password-Stor…...

康奈尔大学 AlScN/GaN 异质结构研究“单通道和多通道 AlScN 势垒”

康奈尔大学的研究团队声称&#xff0c;利用铝钪氮&#xff08;AlScN&#xff09;势垒开发的氮化镓&#xff08;GaN&#xff09;单通道和多通道异质结构&#xff0c;实现了迄今为止最低的薄层电阻&#xff08;Sheet Resistance&#xff09;。这项工作旨在推动下一代高速、高功率…...