首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

算法-排序算法-快速排序

/** * 排序算法-快速排序 * 快速排序(Quick Sort)算法和冒泡排序算法类似,都是基于交换排序思想快速排序算法对冒泡排序算法进行了改进,从而具有更高执行效率。...* 快速排序算法通过多次比较和交换来实现排序,过程如下: * (1)首先设定一个分界值,通过该分界值将数组分成左右两部分。...* (3)然后,左边和右边数据可以独立排序。对于左侧数组数据,又可以取一个分界值,将该部分数据分成左右两部分,同样将左边放置较小值,右边放置较大值。右侧数组数据也可以做类似处理。...通过递归将左侧部分排好序后,再递归排好右侧部分顺序。当左、右两部分各数据排序完成后,整个数组排序也就完成了。...:" + Arrays.toString(ints)); quickSortFun(ints, 0, size - 1); System.out.println("排序数组

88010
  • 您找到你想要的搜索结果了吗?
    是的
    没有找到

    排序算法-快速排序

    1.快速排序(递归) 快速排序是 Hoare 于 1962 年提出一种二叉树结构交换排序方法,其基本思想为: 任取待排序元素序列中 某元素作为基准值,按照该排序码将待排序集合分割成两子序列,左子序列中所有元素均小于基准值.../[begin,keyi-1]keyi[keyi+1,end] QuickSort(a, begin, keyi - 1); QuickSort(a, keyi + 1, end); } 上述为快速排序递归实现主框架...,发现与二叉树前序遍历规则非常像,同学们在写递归框架时可想想二叉 树前序遍历规则即可快速写出来,后序只需分析如何按照基准值来对区间中数据进行划分方式即可。...,因为插入排序最坏情况就是要插入数都比前面的数小,插入排序在小区间里面比较不错一种排序算法,在快速排序里面使用插入排序可以提高很多效率。...(非递归) 非递归快速排序可以借助一个栈来实现,先入右边值,再入左边值,然后每次取值都是先取栈顶,也就是左边值,然后再进行部分排序,直到返回keyi-1=left,就代表着左边排序完成,右边返回

    15510

    排序算法 --- 快速排序

    一、排序思想 将数组中一个数作为基准,比该数小放到左边,比该数大放到右边; 对左右两边再进行上述操作,即把左边当成一个新数组,找新基准数,右边也一样; 直到不能再分割下去为止。...指针重合 指针重合了,就将基准数和指针重合时所指数交换位置,即交换6和3位置,如图: ? 第一躺排序完成 此时6左边都是比它小,右边都是比它大。...左边部分和右边部分看成是两个新排序列,两个序列都按照上述方式再进行排序,先排左边,再排右边。...[i]; arr[i] = arr[j]; arr[j] = temp; } // 跳出了外层while循环,表示i和j...,重复上述步骤 sort(arr, j+1, right); // 排右边 sort(arr, left, i-1); // 排左边 } 快速排序之所以成为快速排序,那就是因为它快

    58831

    排序算法快速排序

    快速排序(Quicksort)是对冒泡排序一种改进。 在实际中最常用一种排序算法,速度快,效率高。...快速排序采用思想是分治思想。...算法介绍: 设要排序数组是A[0]……A[N-1],首先任意选取一个数据(通常选用数组第一个数)作为关键数据,然后将所有比它小数都放到它前面,所有比它大数都放到它后面,这个过程称为一趟快速排序...值得注意是,快速排序不是一种稳定排序算法,也就是说,多个相同相对位置也许会在算法结束时产生变动。...一趟快速排序算法是: 1)设置两个变量i、j,排序开始时候:i=0,j=N-1; 2)以第一个数组元素作为关键数据,赋值给x,即x=rands[0]; 3)从j开始向前搜索,即由后开始向前搜索

    43420

    最快简单排序算法:桶排序

    现在我们举个具体例子来介绍一下排序算法。 ? 首先出场我们主人公小哼,上面这个可爱娃就是啦。期末考试完了老师要将同学们分数按照从高到低排序。...因为其实真正排序要比这个复杂一些,以后再详细讨论,目前此算法已经能够满足我们需求了。 这个算法就好比有11个桶,编号从0~10。...桶排序从1956年就开始被使用,该算法基本思想是由E.J.Issac R.C.Singleton提出来。之前说过,其实这并不是真正排序算法,真正排序算法要比这个更加复杂。...但是考虑到此处是算法讲解第一篇,我想还是越简单易懂越好,真正排序留在以后再聊吧。需要说明一点是:我们目前学习简化版桶排序算法其本质上还不能算是一个真正意义上排序算法。为什么呢?...如果使用我们刚才简化版排序算法仅仅是把分数进行了排序。最终输出也仅仅是分数,但没有对人本身进行排序。也就是说,我们现在并不知道排序分数原本对应着哪一个人!这该怎么办呢?

    1.4K10

    算法快速排序

    快速排序 排序流程: 每次选区第一个数为基准数 然后将大于和小于基准元素分别置于基准数两边 继续分别对基准数两侧未排序数据使用分治法进行细分处理(分而治之),直至整个序列有序。...= low;//从左边开始 int j = high;//从右边开始 int base = arr[low];//定左边第一个为基准书,拿出来之后,该位置就可以被覆盖了 //如果low就是...{ j--; } if (i < j)//右边找到小于基数数 { arr[i++] = arr[j]; } while (i < j && arr...[i] < base)//从左边开始遍历,比基准值小,不做改变,继续遍历,直到碰到比基准值大 { i++; } if (i < j)//左边已经找到大于基数数 {...int high) { if (low < high) { int index = parttion(arr, low, high);//寻找基准值,然后开始分而治之 //index这个位置数已经是它该放位置

    20420

    快速排序算法

    快速排序算法是一个典型荷兰国旗问题。那什么是荷兰国旗问题呢,就是有三种旗子红,白,黑。 三种旗子在数组中乱序,现在问题是要把相同颜色国旗放到一起应该怎么做。...遇到红色旗子放到前面,遇到黑色旗子放到后面。 快速排序就是按这种思路来,指定一个元素为白色旗,小于该元素值认为是红色,大于该元素值认为是黑色。...快速排序关键点: 指定一个数,然后把数据分成两部分,小于该数放到该数前面,大于该数放到该数后面。 前半部分数据和后半部分数据,按同样方法分成两部分。...举个例子来说明一下过程, 数组:6,7,4,3,8来举例看一下一趟快速排序过程。...剩下部分重复上面的过程直到单个只有单个元素。

    38130

    算法——快速排序

    一、简介 步骤如下: 从数列中挑出一个元素,称为 “基准”(pivot); 重新排序数列,所有元素比基准值小摆放在基准前面,所有元素比基准值大摆在基准后面(相同数可以到任一边)。...这个称为分区(partition)操作; 递归地(recursive)把小于基准值元素子数列和大于基准值元素子数列排序; 二、编码如下 /** * 快速排序 * * @author xjf...for (int i : arr) { System.out.print(i + " \t"); } } /** * 快速排序实现方法...// 此处这个点值是被赋值到其他位置上,所以需要填充这个点真实值,即为基准值 arr[i] = x; // 上面执行一次排序后,数据根据基准值分成了两块...,再分别对两块进行同样排序 quickSort(arr, low, i - 1); quickSort(arr, i + 1, high);

    41720

    算法快速排序

    ) 【算法】双指针算法 ( 有效回文串 II ) 【算法】哈希表 ( 两数之和 ) 【算法快速排序 ---- 文章目录 算法 系列博客 一、快速排序思想 二、快速排序代码 一、快速排序思想 ---...- 快速排序思想 : 先 整体有序 , 后 局部有序 , 分治算法 ; 先从数组中 挑选出一个数 a , 然后 进行分割 , 将数组分割成两部分 , 左半部分 小于等于 a , 右半部分 大于等于 a...] , 挑选数字时 , 大概率选中 1 , 此时如果要求左半部分严格小于 1 , 此时 左半部分没有任何数值 , 很容易出现不均匀划分 ; 快速排序 理想划分 是每次划分 , 划分左边和右边元素个数基本差不多..., 递归时不会出现极端情况 , 二、快速排序代码 ---- 整数排序 : https://www.lintcode.com/problem/463/ 下面代码中有三个要点 分割中心点选取 ; 指针限制条件...array[left] = pivot , 否则会造成死循环递归 , 导致栈溢出 ; 使用 [3,2,1,4,5] 进行推导 , 即可出现死循环 ; 快速排序时间复杂度是

    75540

    快速排序算法

    快速排序算法本质上是通过把一个数组划分为两个子数组,然后递归调用自身为每一个子数组进行快速排序来实现。 这里首先讲递归快速排序算法。...1.递归排序算法 public void recQuickSort(int left, int right){ if(right-left<=0){ //如果right-left...调用自身对左边一组进行排序。 再次调用自身对右边一组进行排序。 这个递归基值(终止)条件:检查数组是否只包含一个数据项,如果是,就定义数组已经有序,方法返回。...为了简便我们总选择待划分子数组最右端数据项作为枢纽。 划分完成之后,如果枢纽被插入到左右子数组之间分界处,那么枢纽就落在排序之后最终位置上了。 递归排序算法思想简图 ?...这里贴出递归方式快速排序代码实现 package com.vincent.suanfa; public class quickSort1 { public static void main(

    54410

    快速排序算法

    快速排序算法 思想(从小到大排序) 快速排序是使用分治法来完成 基本思想就是先从其中选取一个基准值,然后从数组两端开始移动查找,在右边移动查找到比基准值小数据停止移动,此时在左边查找到比基准值大数据也停止查找...接下来这个基准值将一个数组分成了两半,左边是小,右边是大,那么我们再分别对左边和右边数据进行相同操作,直至不可拆分成新子序列为止。...快速排序最坏运行时间是O(n2),但期望运行时间是O(nlgn)。...那么把相遇那个点数据和基准值交换即可,那么现在在基准值左边都是小,在右边都是大,此时基准值将数组分成了两个子序列,再对子序列进行重复操作,直到不可拆分成子序列。...low=high,就不用排序了 if(low>=high){ return; } int i=low;

    64360

    史上详细图解快速排序方法_快速排序基本步骤

    大家好,又见面了,我是你们朋友全栈君。 0.前言 找了好多贴在都没有找到舒心一次能看懂文章,决定把学明白每一步全部图解出来。...代码在最后 把分享博主里共享教科书图放这 1.图解开始 贴一张大长图 2....代码实现 package learn.algorithm.sort; import java.util.Arrays; import java.util.stream.IntStream; /** * 快速排序...* 应用最广泛排序算法,实现简单,适用于各种不同输入数据且在一般应用中比其他排序算法那都要快多 * 引人注目的特点包括它是原地排序(只需一个很小辅助栈),且长度为N数组排序所需时间和NlgN...错误原因i在上面已经被减过了 fastSort(data,++j,high); } } ---- 文文博客 推荐一个博主文章也很不错:https://blog.csdn.net/weixin_42109012

    39230

    快速排序算法

    快速排序算法基本思想是通过一趟排序将要排序数据分割成独立两部分,其中一部分所有数据都比另外一部分所有数据都要小,然后再按此方法对这两部分数据分别进行快速排序,整个排序过程可以递归进行,以此达到整个数据变成有序序列...我们来看看一趟排序中如何将数据划分为两部分,使得左边部分比给定元素小,而右边部分比给定元素大。 首先,我们选定一个数字作为中轴元素用于划分数据,我们选择数据第一个元素。...然后,我们定义两个指针,分别指向数据首(i)和尾(j)。从后面(j)元素开始进行比较,如果j指向元素大于等于中轴元素,则j–,向前移动一位;否则,交换i和j位置元素。...然后,从前面(i)元素比较,如果i指向元素小于等于中轴,则i++,向后移动一位;否则,交换i和j位置元素。这样一直循环,知道i==j为止。...短短几行代码就完成了Java很多行代码功能!

    43810

    排序算法(七):快速排序

    快速排序是通过分治方式,根据选定元素将待排序集合拆分为两个值域子集合,并对子集合递归拆分,当拆分后每个子集合中元素个数为一时,自然就是有序状态。...快速排序分治流程是根据选定元素,将集合分隔为两个子集合,一个子集合中所有元素不大于选定元素值,另一个子集合中所有元素不小于选定元素值,则用于拆分集合选定元素即为已排序元素。...因为是直接根据位置进行替换,所以相比较于两两相邻元素比较替换效率要高许多,当然也导致了算法不稳定性。...算法分析 快速排序是一种非稳定排序算法,形式上类似于归并排序,操作上刚好相反,一个是对集合先拆分后操作,一个是对集合先操作后拆分。...因为拆分集合过程存在普通二叉树和斜树情况,所以树高为 ~ ,每一层平均比较和交换复杂度为 ,所以累加可得快速排序比较和交换复杂度为 ~ 。

    62030
    领券