快速排序是面试中的几乎必问的问题,理解之后发现并不难,在此贴出两种版本,与小伙伴们相互交流

PS:今天码代码非常有感觉,所以连发三篇博客,下午打球,手感也是热的发烫,希望不忘初心,方得始终。

进入正题,快速排序的基本思路就是的,找出数组中的某一个值,将其摆放在某一位置,比其大,放在该值的右边,比其小放在该值的左边,左右两边继续执行上述步骤,也就是递归。

那么问题来了,C语言中如何找出数组中的某一个值的位置(以下程序均取首项),先看如下分析。

C实现

如图1所示,low代表数组首项,high代码数组末项,找出数组的首项 arr[len],将其储存起来(int val=arr[len]),先比较arr[high]与arr[low] 大小,,如何arr[high]>val,high左移,

如果arr[high]>val,说明数组的顺序已调整好,否则直至arr[high]<val     arr[low]=arr[high]

图1

图2

如果arr[low]<=val  将low右移,当arr[low]>val,arr[high]=arr[low]

图3

如果arr[high]>=val 将high左移,arr[high]<val,arr[low]=arr[high]

图4

如果arr[low]<=val  将low右移,当arr[low]=arr[high],则代表首项的位置找到了,为2所在位置,arr[low]=val;

图5

下来就简单了,对9所在位置的左右依次执行上述操作方法,也就是递归

代码如下:

#include <stdio.h>
void quick_sort(int * a,int low,int high);
int findPos(int * a,int low,int high);
int main(){
int i ;
int arr[]={,,,,-,,,,,,,,};
//求数组的长度
int len=sizeof(arr)/sizeof(arr[]);
//排序
quick_sort(arr,,len-);
//打印
for(i=;i<len;i++){
printf("%d ",arr[i]);
}
printf("\n");
return ;
}
/*递归函数,第一个参数是数组,第二个参数是排序起始点,第三个参数是排序终止点*/
void quick_sort(int * a,int low,int high){
//在low小于high的时候,先找出指定值的位置,本程序指定的是a[0], 在指定值的左右继续执行找位置并赋值
if(low<high){
int pos=findPos(a,low,high);
quick_sort(a,low,pos-);
quick_sort(a,pos+,high);
}
}
int findPos(int * a,int low,int high){
int val=a[low];
while(low<high){
//当a[high]大于val时,不用移动a[high],只需要让high左移,也就是high--,当a[high]<val,则证明该赋值了。
while(low<high && a[high]>=val){
high--;
}
a[low]=a[high];//跳出while执行
//当a[low]<=val,不用移动 a[low],只需要让low右移,也就是low--,当a[low]>val,则证明该赋值了。
while(low<high && a[low]<=val){
low++;
}
a[high]=a[low];//跳出while执行
}//跳出总的while 代表low==high,则只需要把val赋给 a[low]或 a[high] ,最终return low或high 作为递归分界线
a[low]=val;
return low;
}

JS实现

js实现,也是比较容易,找出一个中间值,比其小放在左边,比其大放在右边,左右递归,有一点注意,在判断与mid[0]的大小时,循环从1开始,而不是0.

伪代码:

var arr=Array.length; //长度
if(arr<=1){return arr.slice(0);}
var left=[];//左
var right=[];//右
var mid=[Array[0]];//中间值
for(var i=1;i<len;i++){
if(Array[i]<mid[0]) left.push(Array[i])
else right.push(Array[i]);
}
return left.sort.concat(mid.concat(right.sort()))//递归

用面向对象去写,就是在数组的原型上添加一个方法,测试时去调用这个方法即可

Array.prototype.quick_sort=function(){
var len=this.length;
if(len<=1){
return this.slice(0);
}
var left=[];
var right=[];
var mid=[this[0]];
for(var i=1;i<len;i++){
if(this[i]<mid[0]){
left.push(this[i]);
}
if(this[i]>=mid[0]){
right.push(this[i]);
}
}
return left.quick_sort().concat(mid.concat(right.quick_sort()));
}
var arr = [31, 1, -5, -6, 10, 9, 0, 14, 222];
arr=arr.quick_sort();
console.log(arr);

这是测试的结果

图6

比较两者区别

C实现相对于JS实现代码量能大一点,C中多了一步就是把首项的值,放到合适的位置,而JS固定好了中间值,就是第一项,比中间值小的放在中间值的左边,比中间值大的放在中间值的右边,再调用递归

快速排序的数据结构是不确定的,时间复杂度是O(n^2), 最优时间复杂度为O(n log n),平均时间复杂度也为O(n log n),空间复杂度取决于程序的实现方法。

这就是我对快排的理解。

快速排序之C实现和JS实现的区别的更多相关文章

  1. js == 与 === 的区别,‘’与“”的区别

    js == 与 === 的区别 1.对于string,number等基础类型,==和===是有区别的 1)不同类型间比较,==之比较"转化成同一类型后的值"看"值&quo ...

  2. 小tips:JS数值之间的转换,JS中最大的Number是多少?,JS == 与 === 的区别

    JS数值之间的转换 Number(), parseInt(),parseFloat() Number()函数的转换规则如下: 1.如果boolean值,true和false将分别被转换为1和02.如果 ...

  3. JQ的offset().top与js的offsetTop区别详解

    一.前言 最近在做一个图片懒加载的插件,就纵轴(Y轴)而言,我需要时时获取图片的上偏移量,好判断是否已进入视图区域,而我所理解的是offsetTop应该是跟offset().top一样的,然后陷入了因 ...

  4. js forEach for区别

    1.循环中断差别 具体见示例代码: <!DOCTYPE html> <html lang="zh"> <head> <meta chars ...

  5. js中单引号和双引号的区别(html中属性规范是用双引号,js中字符串规定是用单引号)(js中单引号区别和php很像:单引号快,双引号可转义字符,双引号可解析变量)

    js中单引号和双引号的区别(html中属性规范是用双引号,js中字符串规定是用单引号)(js中单引号区别和php很像:单引号快,双引号可转义字符,双引号可解析变量) 一.总结 1.html中属性规范是 ...

  6. JQ的offset().top与JS的getBoundingClientRect区别详解,JS获取元素距离视窗顶部可变距离

     壹 ❀ 引 我在 JQ的offset().top与js的offsetTop区别详解 这篇博客中详细分析了JQ方法offset().top与JS属性offsetTop的区别,并得出了一条offset( ...

  7. php和js的小区别

    1.今天看了下php的api感觉还可以,不是很难,可能没看到深入的地方, (1)和js很相似 目前感觉它和js的最大区别 js的  点  被替换成 -> function setCate($pa ...

  8. JS与Jquery区别

    很多人对JS和JQuery很容易搞混淆,今天我们就相比学习下: 加载区别: var myfunction(){}; JS:1.window.onload=function(){} 2.<body ...

  9. 浅析angular,react,vue.js jQuery使用区别

    前端越来越混乱了,当然也可以美其名曰:繁荣.当新启动一个前端项目,第一件事就是纠结:使用什么框架,重造什么轮子? PS:大牛留言讨论那么,希望看完此篇,能够给你一个清晰的认识,或者让你更加地纠结和无所 ...

随机推荐

  1. golang并发

    1.goroutine goroutine是Go并行设计的核心.goroutine说到底其实就是线程,但是它比线程更小,十几个goroutine可能体现在底层就是五六个线程,Go语言内部帮你实现了这些 ...

  2. nautilus pg autoscaler PG自动伸缩

    链接地址:https://ceph.io/rados/new-in-nautilus-pg-merging-and-autotuning/ [root@controller ~]# ceph osd ...

  3. fsck知识点记录

    最近处理一个生产环境问题时,碰下一个以下现象,记录一下,便于以后出现类似问题时,快速的查找相应命令 问题现象 由于物理机的内存条出现故障,导致该节点上的所有虚机网络都不通,机房人员修复完物理内存以后, ...

  4. 团队作业3 需求改进&系统设计(银河超级无敌舰队)

    目录 一.需求&原型改进 1. 需求改进 2. 修改说明书 3.功能分析 4. 调整WBS及计划 二.系统设计 1. 总体设计 2. 数据库设计 3.社团设计 三.Alpha任务分配计划 1. ...

  5. 第2篇 Scrum 冲刺博客

    1.站立会议 照骗 进度 成员 昨日完成任务 今日计划任务 遇到的困难 钟智锋 无 确定客户端和服务器通信的形式 各成员的代码难以统一 庄诗楷 无 编写客户端UI 加入图片总是失败 易德康 无 马,车 ...

  6. Java14版本特性【一文了解】

    「MoreThanJava」 宣扬的是 「学习,不止 CODE」,本系列 Java 基础教程是自己在结合各方面的知识之后,对 Java 基础的一个总回顾,旨在 「帮助新朋友快速高质量的学习」. 当然 ...

  7. 问卷星导入数据到SPSS,数据变成-3是什么原因?

    问卷星将数字“-3”表示为筛选或者跳转题:如果问卷中有设计筛选或者跳转,此时则会出现“-3”这个数字. 解决办法1 分析时首先进行筛选,然后再分析,便不会出现“-3”,而且一定需要这样进行.“筛选样本 ...

  8. OpenGL学习日志(2020.4之前)

    咳咳,原本这个日志是本机上随便写的一些记录,也没怎么注意可读性和格式,有用信息密度很小,所以实用价值并不大.暂时由于不可抗因素得先鸽一段落了... 后续的日志会升格为模块化的学习记录,(应该)将会有很 ...

  9. 模拟画图题P1185 绘制二叉树

      题目链接P1185 绘制二叉树 题意概述   根据规则绘制一棵被删去部分节点的满二叉树.节点用 \(o\) 表示,树枝用/\表示.每一层树枝长度会变化,以满足叶子结点有如下特定: 相邻叶子节点是兄 ...

  10. Windows server 2008 搭建DNS服务

    现在用Windows搭建DNS的已经很少了,感觉也只有一些公司的某块部分能用上,最近在捣鼓这个,索性直接写下来,以后可以看了直接用. 开始: ★★★配置静态IP地址 老样子,有关服务器功能的建立,都是 ...