面试官:手写一个快速排序吧(Java实现)

小郝不负流年
小郝不负流年   + 关注
2021-03-17 12:34:10   阅读505   评论0

快速排序基于分治思想,它的时间平均复杂度很容易计算得到为O(NlogN)。

思路:

从数列中挑出一个元素,称为“基准”,重新排序数列,所有元素比基准值小的摆放在基准前面,所有元素比基准值大的摆在基准的后面(相同的数可以到任一边),在这个分割之后,该基准是它的最后位置。这个称为分割(partition)操作。递归地把小于基准值元素的子数列和大于基准值元素的子数列排序。

实现代码:


  1. package cn.hoscen.demo.sort;  
  2.   
  3. import java.util.Arrays;  
  4.   
  5. /** 
  6.  * Description: 手写快速排序算法 分治法 -- 升序排序 
  7.  * 从数列中挑出一个元素,称为“基准” 
  8.  * 重新排序数列,所有元素比基准值小的摆放在基准前面,所有元素比基准值大的摆在基准的后面(相同的数可以到任一边)。在这个分割之后, 
  9.  * 该基准是它的最后位置。这个称为分割(partition)操作。 
  10.  * 递归地把小于基准值元素的子数列和大于基准值元素的子数列排序。 
  11.  * Created by Hoscen on 2021/3/16 21:39 with IntelliJ IDEA. 
  12.  */  
  13. public class QuickSort {  
  14.   
  15.     public static void main(String[] args) {  
  16.         int[] arrs = {493865977613277834};  
  17. //        int[] arrs = {49, 38, 65};  
  18.         System.out.println(Arrays.toString(arrs));  
  19.         int[] sortArrs = quickSort(arrs);  
  20.         System.out.println(Arrays.toString(sortArrs));  
  21.   
  22.     }  
  23.   
  24.     private static int[] quickSort(int[] arrs) {  
  25.         if (arrs == null || arrs.length < 1) {  
  26.             return null;  
  27.         }  
  28.         if (arrs.length == 1) {  
  29.             return arrs;  
  30.         }  
  31.         if (arrs.length == 2) {  
  32.             if (arrs[0] > arrs[1]) {  
  33.                 int tmp = arrs[0];  
  34.                 arrs[0] = arrs[1];  
  35.                 arrs[1] = tmp;  
  36.             }  
  37.             return arrs;  
  38.         }  
  39.         sort(arrs, 0, arrs.length - 1);  
  40.         return arrs;  
  41.     }  
  42.   
  43.     private static void sort(int[] arrs, int startIndex, int endIndex) {  
  44.         if (startIndex < endIndex) {  
  45.             int partition = partition(arrs, startIndex, endIndex);  
  46.             sort(arrs, startIndex, partition - 1);  
  47.             sort(arrs, partition + 1, endIndex);  
  48.         }  
  49.     }  
  50.   
  51.     /** 
  52.      * sort 返回中轴下标 
  53.      * Created by Hoscen on 2021/3/16 21:43 
  54.      * 
  55.      * @param arrs 
  56.      * @param startIndex 
  57.      * @param endIndex 
  58.      * @return int 
  59.      */  
  60.     private static int partition(int[] arrs, int startIndex, int endIndex) {  
  61.         int temp = arrs[startIndex];  
  62.         while (startIndex < endIndex) {  
  63.             while (startIndex < endIndex && arrs[endIndex] >= temp) {  
  64.                 endIndex--;  
  65.             }  
  66.             arrs[startIndex] = arrs[endIndex];  
  67.             while (startIndex < endIndex && arrs[startIndex] <= temp) {  
  68.                 startIndex++;  
  69.             }  
  70.             arrs[endIndex] = arrs[startIndex];  
  71.         }  
  72.         arrs[startIndex] = temp;  
  73.         return startIndex;  
  74.     }  
  75. }  


对我有用,我要     转载  
文章分类: Java  
所属标签: Java   快速排序  
  • 0条评论
  • 只看作者
  • 按时间|按热度
  • 由于本人多次涉及需要打印这个证明,而每次都会忘记入口,在网上各种搜索各种摸索很是浪费时间。故本次将操作流程整理记录下来,以备忘。同时也分享给大家。1、打开湖北政务服务网,地址:http://zwfw.hubei.gov.cn/s/index.html2、切换区域到“武汉市”3、在“特色服务”模块找到“(个人)武汉市社会保险公共服务平台”4、进入“(个人)武汉市社会保险公共服务平台”,登录账号密码<imgsrc="https://cdnstatic.hoscen.cn/blog/article/184053017752895488/img/497065960be44747825acb86a17483c1.png"style=
  • 一般我们在使用CDN时都设置有缓存时间,当源站资源发生变更后,如果缓存时间没到,那么用户访问的依旧是变更前的数据,虽说又拍云控制台提供了缓存刷新功能界面,但是每次都手动去刷新显示不太理想,当然又拍云也想到了这一点,提供给我们有API可以调用。本篇文章就是讲解如何接入又拍云缓存刷新API。网站免费接入又拍云CDN的方法,请查看我另外一篇文章,地址: https://www.hoscen.cn/blog/hao/articles/204022774975430656.html又拍云API文档:https://api.upyun.com/doc#/api/guide/overview看完文档,我们会知道又拍云提供有两个缓存刷新接口,一个支持通配符(但次数有限),一个是完整url刷新。同时注意调用接口时将 Token 放入 HTTP Header 中 。那么我们需要3个接口:1、获取token2、URL刷新3、缓存批量刷新详细请求参数和响应值请查看文档。话不多说,我们直接放上核心代码1、获取token2、URL刷新<img src="https://cdnstatic.hoscen.cn/blog/article/
  • 1. 两数之和

    阅读数539
    总结:1、解决方法通常我们最容易想到的是暴力枚举(双重for循环),时间复杂度O(N^2),空间复杂度O(1),其中N是数组中的元素数量 2、利用哈希表可以以空间换时间,时间复杂度O(N),空间复杂度O(N),其中N是数组中的元素数量 题目给定一个整数数组nums和一个目标值target,请你在该数组中找出和为目标值的那两个整数,并返回他们的数组下标。你可以假设每种输入只会对应一个答案。但是,数组中同一个元素不能使用两遍。示例:给定nums=[2,7,11,15],target=9因为nums[0]+nums[1]=2+7=9所以返回[0,1]答案第一版:暴力枚举,时间复杂度高public int[] twoSum(int[]nums, int target){   int len=nums.length;   
  • 什么是内卷?

    阅读数537
    最近一个词频频引起热议:内卷可能很多人看到都是一脸懵或者一脸冷漠:这啥玩意,跟我有什么关系?实际上,内卷与你的生活、工作、甚至未来都息息相关百度百科上的解释是:指一种社会某一发展阶段达到某种确定的形式之后,这种形式便停滞不前,难以转化为另一种高级模式的现象,从而把自我锁死在低水平状态上,周而复始地循环。这⼀概念最早是⽤来研究⽖哇的⽔稻农业。在殖⺠地时代和后殖⺠地时代的⽖哇,农⺠在⼈⼝压⼒下不断增加⽔稻种植过程中的劳动投⼊,以获得较⾼的产量。但实际上,当地农业⽣产⻓期原地不动,只是不断地重复简单再⽣产,不能提⾼单位⼈均产值。根据简单的经济学常识就知道,劳动的超密集投⼊,不会带来产出的成⽐例增⻓,⽽会导致单位劳动边际报酬递减。举一个咱们有代入感的例子在一家公司,所有员工都按时上下班,完成8小时的工作量。但突然有一个新员工A来了,他任劳任怨、自愿加班完成10小时的工作量,他的努力也获得了领导的欣赏与嘉奖。其他
  • 生活中难免有觉得“好累啊”的时候,岁月在不同阶段将不同压力倾轧到不同人身上,那些时刻降临时,多半只能靠自己挺过去,“人应该有力量,揪着自己的头发把自己从泥地里拔起来。”  10种疲累,10个“解药”。给累了的你。《如果,你觉得很累很累……》No.1明明休了周末,周一上班还是觉得:好累啊……一剂解药:所谓的休息并不单纯只有躺下,而是做自己想做的事,不做自己不想做的事情。休息有“储存的休息”和“释放的休息”两种。“储存的休息”通过休息来储存体力和活力。“释放的休息”则通过做喜欢的事情来释放平日累积的郁闷和压力。“储存的休息”不足时身体会坏掉,“释放的休息”不足时精神会崩坏。开药者丨@bibibi_senseiNo.2总是活在别人的眼光里,总是被他人的评价所左右,好累啊……一剂解药:纵使被说坏话
  • 数据结构绪论

    阅读数537
    1、数据结构起源早期计算机被理解为数值计算工具,但是我们还有一些非数值的计算,因此需要一些更科学有效的手段(比如表、树、图等数据结构)的帮助来处理问题。所以数据结构是一门研究非数值计算的程序设计问题中的操作对象以及它们之间的关系和操作等相关问题的学科。2、基本概念和术语2.1 数据数据:是描述客观事物的符号,是计算机中可以操作的对象,是能够被计算机识别,并能输入给计算机处理的符号集合。数据不仅包括整型、实型等数值类型,还包括字符、声音、图像、视频等非数值类型。我们所说的数据,其实就是符号,但是这个符号需要满足两点:能输入到计算中能被计算机程序处理2.2 数据元素数据元素,也被称为记录。是组成数据的、具有一定意义的基本单位。比如,在人类中,人就是数据元素。在禽类中,猪狗牛羊等动物就是禽类的数据元素。2.3 数据项数据项:一个数据元素可以由若干个数据项组成。比如 人这个数据元素,就可以有眼、耳、鼻等数据项,也可以有姓名、年龄等数据项。具体有哪些数据项是视你所做的系统来决定。数据项是数据不可分割的最小单位。但注意真正讨论问题时,数据元素才是数据结构中建立数据模型的着眼点。就像我们讨论一个电影,通常是讨论角色这个“数据元素”,而不是讨论角色的姓名、年龄这些“数据项”。2.4 数据对象数据对象:是性
  • 本文主要讲canonical标签的使用、canonical标签的作用、canonical标签SEO,在实践中如何正确规范的使用canonical标签。Canonical标签实际上就是一个页面内的301转向,可以帮助我们解决内容一样url不一样的网址规范化问题。和301跳转不同的是,用户并不被转向,但是对于搜索引擎来说,页面链接的权重是会被集中到代码中指明的规范化url上的。 图片来源:一灯出海对于经验丰富的SEO人员来说,canonical标签的使用一定不陌生,但最近在实践中发现不少网站的页面虽然用了canonical标签,但是使用方法却不规范。所以在这里和大家一起探讨一下canonical标签的规范使用方法,让更多的SEO人员避免走弯路。如果一个页面有多个url:https://www.hoscen.cn/blog/hao/articles/211896161185824768.htmlhttps://www.hoscen.cn/blog/hao/articles/211896161185824768/view这些url的页面内容完全一样,而我们想优化的规范化url为<ahref="https://www.hoscen.cn/blog/ha
  • 本文主要讲到PMP考试介绍、PMP考试试题分布、考题类型、PMI理念、答题技巧、学习方法与建议。PMP考试介绍1、它是笔试,200道选择题,都是单选题,四选一;2、不做选择,算答错。选了多个,也算错; 3、中英文对照,对于中国考生看中文就可以了,但是有些题的翻译不好,所以当读到题目有些别扭、或者觉得选项与题目都有点不符的时候,有些细节还是需要对照一下英文的; 4、200题里面有25题不计分,是PMI用来测试本次考试是否太难、太容易、或者争议非常大的题目。但是这25题并不知道是哪些,随机散乱的分布在试卷中。 5、所以200题的PMP考试,总分是200分,131及以上算是及格,我们对自己的要求当然是200分啦。 6、考试答题时间:9:00~13:00,共计4个小时。因为正式考试需要涂写答题卡,因此平时做题的时候,要控制时间,尽量在3小时内完成。 PMP考试试题分布过程组比例题目数量启动过程组13%26题规划过程组24%48题
  • SQL计算日期相差多少分钟,示例SELECT  ROUND(TO_NUMBER(to_date(rs.t_cap_wf_finReq_start_date,'YYYY/MM/DDhh24:mi:ss')-to_date(rs.t_cap_wf_start_date,'YYYY/MM/DDhh24:mi:ss'))*24*60) FROM table_xxx 更多差值单位写法天:ROUND(TO_NUMBER(END_DATE-START_DATE))小时:ROUND(TO_NUMBER(END_DATE-START_DATE)*24)分钟:ROUND(TO_NUMBER(END_DATE-START_DATE)*24*60)秒:ROUND(TO_NUMBER(END_DATE-START_DATE)*24*60*60)毫秒:ROUND(TO_NUMBER(END_DATE-START_DATE)*24*60*60*1000) 
  • xxx:郝实诚!你真的叫这个名字啊? 我:对啊  不止一次....-- 大家好,我叫郝实诚,真的很实诚。