news 2026/1/11 17:28:06

快速排序的优化:荷兰国旗问题

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
快速排序的优化:荷兰国旗问题

测试

PTA:校内链接7-1 排序 - Search & Sort(信安24)

题目

图解

因为嗯,我觉得文字描述太干了,而且很难看也是画了个图解好理解一点ovo

首先是一个乱序的数组我们给他排序,我们先设置两个界限,和三个指针,下面会给出每个东西的含意,和基本的逻辑

然后我们来模拟逻辑

代码

#include<iostream> using namespace std; const int N = 1e5 + 2; int arr[N]; int first, last;//全局变量作为partition的返回值 void swap(int x, int y) { int temp = arr[x]; arr[x] = arr[y]; arr[y] = temp; } void partition(int l, int r, int x) { first = l, last = r; int i = l; while (i <= last) { if (arr[i] == x) i++; else if (arr[i] < x) { swap(i++, first++); } else { swap(last--, i); } } } void sort(int l,int r) { if (l >= r) return; partition(l, r, arr[(l + r) / 2]); int fir = first; int las = last; sort(l, fir - 1); sort(las + 1, r); } int main() { int n; cin >> n; for (int i = 0; i < n; i++) cin >> arr[i]; sort(0, n - 1); for (int i = 0; i < n; i++) cout << arr[i] <<" "[i==n-1]; }

结果

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/1/4 14:07:44

智能检索系统进阶指南:解锁代理规划与深度推理双引擎实战

智能检索系统进阶指南&#xff1a;解锁代理规划与深度推理双引擎实战 【免费下载链接】azure-search-openai-demo A sample app for the Retrieval-Augmented Generation pattern running in Azure, using Azure AI Search for retrieval and Azure OpenAI large language mode…

作者头像 李华
网站建设 2025/12/20 23:48:33

大模型应用技术之 Spring AI 2.0 变更说明

概述 Spring AI 2.0.0-M1 是 Spring AI 框架的一个重要里程碑版本&#xff0c;在 Spring AI 1.x 的基础上进行了重大升级和改进。该版本基于 Spring Boot 4.0 和 Spring Framework 7.0 构建&#xff0c;提供了更强大的 AI 应用开发能力&#xff0c;增强了与各种 AI 模型和服务的…

作者头像 李华
网站建设 2025/12/22 16:37:18

EmotiVoice在语音贺卡App中的情感传递价值

EmotiVoice在语音贺卡App中的情感传递价值 在数字通信日益高效的今天&#xff0c;人与人之间的交流却似乎越来越“扁平化”——一条条冷冰冰的文字消息滑过屏幕&#xff0c;祝福变得模板化&#xff0c;情绪被压缩成几个表情符号。尤其是在节日、生日或重要纪念日&#xff0c;我…

作者头像 李华
网站建设 2026/1/11 14:45:27

46、Linux 系统内核管理与网络故障排查指南

Linux 系统内核管理与网络故障排查指南 1. 内核管理 在 Linux 系统中,有时需要对内核进行管理,例如切换到旧内核或添加新内核。 1.1 启动旧内核 若要启动旧内核,可重启系统,并在启动提示时输入“safe”标签。 1.2 使用 GRUB 配置多内核启动 如果系统使用 GRUB,可修改…

作者头像 李华
网站建设 2025/12/22 5:27:43

glTFast终极指南:Unity中快速加载3D模型的完整方案

glTFast终极指南&#xff1a;Unity中快速加载3D模型的完整方案 【免费下载链接】glTFast Efficient glTF 3D import / export package for Unity 项目地址: https://gitcode.com/gh_mirrors/gl/glTFast 在当今的Unity 3D开发中&#xff0c;高效的模型加载已成为项目成功…

作者头像 李华
网站建设 2025/12/21 15:50:13

PiKVM定制化构建指南:从零打造专属远程管理系统的完整实践

PiKVM定制化构建指南&#xff1a;从零打造专属远程管理系统的完整实践 【免费下载链接】pikvm Open and inexpensive DIY IP-KVM based on Raspberry Pi 项目地址: https://gitcode.com/gh_mirrors/pi/pikvm 你是否曾经遇到过这样的困境&#xff1a;在机房外需要重启服务…

作者头像 李华