排序算法 --- 快速排序

1. 原理

首先, 在一个待排序序列中, 以第一个元素为基准, 让序列中所有的基准小的元素在该元素左边, 比其大的元素在其右边. 算法是一种原地算法, 首先把序列里面从基准开始的下一个元素一直到序列尾, 分成左右部分, 左边的都是小的, 右边的都是大的, 最后把基准跟中点交换一下, 再递归对左右部分进行同样的方法排序, 直到所有有序. 那么怎么实现基准后的元素左小右大呢, 可以用双指针的方法.

2. 算法实现

2.1 递归实现

void quikSort(vector<int>& nums, int start, int end) {if (start >= end)return;int mark = nums[start];int left = start + 1;int right = end;while (left < right) {if (nums[left] <= mark) {left ++;continue;}if (nums[right] >= mark) {right --;continue;}swap(nums[left], nums[right]);}if (nums[left] > mark)left --;swap(nums[start], nums[left]);quikSort(nums, start, left - 1);quikSort(nums, left + 1, end);
}
vector<int> sortArray(vector<int>& nums) {int n = nums.size();quikSort(nums, 0, n - 1);return nums;
}

2.2 迭代实现

vector<int> sortArray(vector<int>& nums) {int n = nums.size();if (n < 2)return nums;queue<pair<int, int>> sort_q;sort_q.push(make_pair(0, n - 1));while (!sort_q.empty()) {int start = sort_q.front().first;int end = sort_q.front().second;sort_q.pop();int left = start + 1;int right = end;while (left < right) {if (nums[left] < nums[start])left ++;else if (nums[right] > nums[start])right --;else {swap(nums[left], nums[right]);}}if (nums[left] > nums[start])left --;swap(nums[start], nums[left]);if (left - 1 > start)sort_q.push(make_pair(start, left - 1));if (left + 1 < end)sort_q.push(make_pair(left + 1, end));}return nums;
}

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

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

相关文章

python按列读取txt文件_如何使用pandas读取txt文件中指定的列(有无标题)

最近在倒腾一个txt文件&#xff0c;因为文件太大&#xff0c;所以给切割成了好几个小的文件&#xff0c;只有第一个文件有标题&#xff0c;从第二个开始就没有标题了。 我的需求是取出指定的列的数据&#xff0c;踩了些坑给研究出来了。 import pandas as pd # 我们的需求是 取…

C++的一些关键字

volatile 用volatile声明的变量, 是通知编译器, 该变量为时刻变化的变量, 编译时不要对其进行优化, 每次使用该变量的时候必须从其地址进行读取. (以下是个人理解)一般在多线程中的状态变量会被该关键字声明. 而标准使用场景是: 并行设备的硬件寄存器&#xff08;如&#xf…

python doc_2019-2020年Python3中文教程完整版.doc

Python已经是3.1版本了,与时俱进更新教程.本文适合有Java编程经验的程序员快速熟悉Python本文程序在windows xppython3.1a1 测试通过.本文提到的idle指python shell,即安装python后你在菜单看到的IDLE(python gui)在idle里ctrln可以打开一个新窗口,输入源码后ctrls可以保存,f5运…

C++数据的一些注意事项

1 不同类型 1.1 静态变量 分类&#xff1a; 分为静态全局变量和静态局部变量 作用域&#xff1a; 需要注意静态全局变量也仅仅是在本文件中可用&#xff0c;除非加extern关键字。 内存分配位置 在全局区分配空间&#xff0c;初始值为0。 1.2 局部非静态变量 内存分配位…

python打包的exe如何免杀_如何使用Python进行Payload免杀

很多渗透工具都提供了权限维持的能力&#xff0c;如Metasploit、Empire和Cobalt Strike&#xff0c;但是都会被防病毒软件检测到恶意行为。在探讨一个权限维持技巧的时候&#xff0c;似乎越来越多的人关注的是&#xff0c;这个方式会不会被被杀软杀掉&#xff1f; 打造免杀的pa…

C++指针注意事项

指针占用空间 32位操作系统下指针占用四个字节的空间. 64位下占用8个字节. const 指针组合 const修饰指针 --- 常量指针 声明 const T *p xxx; 特点 指针指向可以修改, 但是指针指向的值不可以修改. 比如: int a 10; int b 20; const int *p &a; *p 20; …

C++内存分类

1 栈 存放的数据&#xff1a; 局部变量&#xff0c;函数参数&#xff0c;返回地址等。 默认初始值&#xff1a; 无默认初始值&#xff0c;为随机值。 分配者&#xff1a; 有编译器自动分配。 分配大小&#xff1a; 在程序开始后分配固定大小的栈空间&#xff0c;如果申…

jpa多表关联查询_Spring Boot 整合mybatis如何自定义 mapper 实现多表关联查询

上一篇文章已经介绍了自定义 mapper 实现自定义的方法&#xff0c;其实实现了通过自定义的mapper就可以做多表关联等复杂查询。但是很多朋友还是反馈说没有实现多表关联查询&#xff0c;所以&#xff0c;今天把文章又重新修改了&#xff0c;增加了多表关联的实现步骤。Mybatis …

spark on yarn 完全分布式_「大数据」(七十一)Spark之架构介绍

【导读&#xff1a;数据是二十一世纪的石油&#xff0c;蕴含巨大价值&#xff0c;这是情报通大数据技术系列第[71]篇文章&#xff0c;欢迎阅读和收藏】1 基本概念Spark 架构采用了分布式计算中的 Master-Slave 模型。 Master 是对应集群中的含有 Master 进程的节点&#xff0c;…

计算机网络数据链路层 --- 停止等待协议

停止等待协议的意义 除了比特出差错&#xff0c;底层信道还会出现丢包问题。为了实现流量控制。 停止等待协议的前提 虽然现在常用全双工通信方式&#xff0c;但为了讨论问题方便&#xff0c;仅考虑一方发送数据&#xff08;发送方&#xff09;&#xff0c;一方接收数据&…

python import如何使用_python之import引用

关于python的import引用的最大关键是init.py文件的作用&#xff0c;这个文件对于import的方法使用至关重要。这个是我在搭建自动化框架过程中用到的import的方法使用。 比如说&#xff0c;我现在login.py想引用bottom底下的log.py的时候&#xff0c;这个时候&#xff0c;我们如…

计算机网络数据链路层 --- 后退n帧协议(GBN)

滑动窗口 发送窗口 发送方维持一组连续的允许发送的帧的序号 接收窗口 接收方维持一组连续的允许接收帧的序号 发送过程 如图&#xff0c;假如发送方的发送窗口大小是6&#xff0c;首先发送0号帧&#xff0c;并建立0号帧的副本&#xff0c;防止帧丢失&#xff0c;然后发送…

简要描述内部连接和外部连接之间的区别_创新性的M12推拉式连接器推拉标准—跨制造商自动化技术的里程碑...

“八家知名制造商 – 菲尼克斯&#xff0c;浩亭&#xff0c;莫仕&#xff0c;穆尔电子&#xff0c;宾德&#xff0c;康耐&#xff0c;艾查和魏德米勒因建立M12推拉式连接器的推拉锁紧机制而在市场上确立了地位。我们共同追求一个目标&#xff0c;即确保各个制造商之间的兼容性。…

计算机网络数据链路层 --- 选择重传协议(SR)

引言 GBN协议的弊端 累计确认&#xff0c;从而导致某一帧错误后会批量重传。 可行的解决方案 可以只重传出错的帧&#xff0c;设置单个确认&#xff0c;同时加大接收窗口&#xff0c;设置接收缓存&#xff0c;缓存乱序到达的帧。这也就是选择重传协议SR。 SR中的滑动窗口 …

requests 返回的cookies为空_爬虫学习(2)(requests库)

POST请求import requestsdata {name: cxc, age: 18} r requests.post("http://httpbin.org/post", datadata) print(r.text)POST请求这样就成功地获得了返回结果&#xff0c;form部分就是提交的数据&#xff0c;证明POST请求成功发送了。响应之前我们使用了text和c…

计算机网络 --- 数据链路层的功能

数据链路层在物理层提供服务的基础上向网络层提供服务, 其最基本的服务是将源自网络层来的数据可靠地传输到相邻结点的目标机网络层, 其主要作用是加强物理层传输原始比特流的功能, 将物理层提供的可能出错的物理链接改造成为逻辑上无差错的数据链路, 使之对网络层表现出一条无…

pytorch元素相乘_bert_pytorch学习(1)

本文主要是记录学习bert的pytorch实现代码的一些心得dataset1. vocab继承关系&#xff1a;TorchVocab --> Vocab --> WordVocabTorchVocab该类主要是定义了一个词典对象&#xff0c;包含如下三个属性&#xff1a;freqs&#xff1a;是一个collections.Counter对象&#xf…

计算机网络 --- 数据链路层介质访问控制

引言 传输数据使用的两种链路&#xff1a; 点对点链路&#xff1a;两个相邻的节点通过一个链路相连&#xff0c;没有第三者。应用&#xff1a;PPP协议&#xff0c;常用于广域网。广播式链路&#xff1a;所有主机共享通信介质。应用&#xff1a;早期的总线以太网&#xff0c;无…

6-7 使用函数输出水仙花数_学习C语言居然对printf函数不理解???

对于C语言的printf函数&#xff0c;可以说是我们学习C语言第一个接触到的函数了。printf命令的作用是格式化输出函数&#xff0c;一般用于向标准输出设备按规定格式输出信息。printf()函数的调用格式为&#xff1a;printf("", )。printf()是C语言标准库函数&#xff…

计算机网络 --- 数据链路层aloha协议

纯aloha协议 纯aloha协议思想 不监听信道&#xff0c;不按时间发送&#xff0c;随机重发。 冲突&#xff1a; 如果信道上如果只有一对节点在通信&#xff0c;那么可以顺利完成该次通信。方式如果发送完成之前又有一次不同方之间的通信发生&#xff0c;这样就会造成信道冲突…