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

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

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

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

排序算法-快速排序

1.快速排序(递归) 快速排序是 Hoare 于 1962 年提出一种二叉树结构交换排序方法,其基本思想为: 任取待排序元素序列中 某元素作为基准值,按照该排序码将待排序集合分割成两子序列,左子序列中所有元素均小于基准值.../[begin,keyi-1]keyi[keyi+1,end] QuickSort(a, begin, keyi - 1); QuickSort(a, keyi + 1, end); } 上述为快速排序递归实现主框架...2.1三数取中 三数取中是取大小位于中间值放到最左边,这样可以防止快排中最坏情况出现O(n*2),也就是要排序这一组数据接近有序或者就是有序情况,那么使用了三数取中后这种最坏情况就变成了最好情况...,因为插入排序最坏情况就是要插入数都比前面的数小,插入排序在小区间里面比较不错一种排序算法,在快速排序里面使用插入排序可以提高很多效率。...(非递归) 非递归快速排序可以借助一个栈来实现,先入右边值,再入左边值,然后每次取值都是先取栈顶,也就是左边值,然后再进行部分排序,直到返回keyi-1=left,就代表着左边排序完成,右边返回

9110

排序算法 --- 快速排序

一、排序思想 将数组中一个数作为基准,比该数小放到左边,比该数大放到右边; 对左右两边再进行上述操作,即把左边当成一个新数组,找新基准数,右边也一样; 直到不能再分割下去为止。...---- 案例: 假如待排序列如下: ? 初始状态 选定6为基准数,然后先从右边开始遍历,找到一个比基准数小数,如下图: ?...指针重合 指针重合了,就将基准数和指针重合时所指数交换位置,即交换6和3位置,如图: ? 第一躺排序完成 此时6左边都是比它小,右边都是比它大。...左边部分和右边部分看成是两个新排序列,两个序列都按照上述方式再进行排序,先排左边,再排右边。...(arr, j+1, right); // 排右边 sort(arr, left, i-1); // 排左边 } 快速排序之所以成为快速排序,那就是因为它快,经测试,排1千万数据大概是1

55031

排序算法快速排序

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

41520

算法快速排序

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

17920

快速排序算法

排序算法思想呢,我看了许多,觉得比较生动是:挖坑填坑再分治。...把第一个数作为基准数(也叫枢轴)挖出来,哨兵j从右往左找出比它小或者等于数,把它挖出来,填进刚刚坑里 填了一个坑,也新挖了一个坑,哨兵i从左往右,找出比基准数大数,又挖出来,填入新坑里 然后又是...最坏情况:$C_{max}=(n-1)+(n-2)+..+1=n(n-1)/2$,$M_{max}\leq C_{min}$,$O(n^2)$   最好情况:$C_{min}\leq O(nlgn)$,...(如果是全局数组a,就不需要)   最好情况:$O(log_2n)$   最坏情况:$O(n)$ 算法改进:   合理选择枢轴:三者取中(选择a[1],a[n]和a[(n+1)/2]中位数),随机产生...稳定性:   是非稳定性排序。如2,2',1,排序后是1,2',2。

48520

快速排序算法

快速排序算法本质上是通过把一个数组划分为两个子数组,然后递归调用自身为每一个子数组进行快速排序来实现。 这里首先讲递归快速排序算法。...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(

51510

快速排序算法

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

61960

快速排序算法

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

41310

算法——快速排序

一、简介 步骤如下: 从数列中挑出一个元素,称为 “基准”(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);

40120

快速排序算法

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

35630

算法快速排序

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

69740

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

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

59530

排序算法快速排序

快速排序 快速排序是一种非常优秀排序算法,应用也非常广泛,面试时面试官也经常让你手写一个快排,所以说学习快速排序是非常有必要快速排序原理 同归并排序一样,快速排序也是一种分治排序算法。...在归并排序中,通过将数组分成两个子数组进行排序,然后对两个有序子数组进行归并以将整个数组排序。而快速排序则是选定一个基准值,然后将大于该值元素放在该元素后面,小于该值元素放在该值前面。...通过不断递归调用来完成排序。 动图演示 ?...,将小于基准值元素放在基准值前面,当两个指针相遇时则说明已经摆放完毕,然后将基准值与j所对应元素交换,通过这样不管递归调用,即可完成排序。...总结 通过对快速排序不断改进,我们发现一个细小改动就可以提升很多性能,快速排序应用非常广泛,一定要掌握很熟练。

35110

算法—史上最好快速算法讲解

前言 快速幂是什么? 顾名思义,快速幂就是快速算底数n次幂。 有多快? 其时间复杂度为 O(log₂n), 与朴素O(n)相比效率有了极大提高。 用多么?...快速幂属于数论范畴,本是ACM经典算法,但现在各厂对算法要求越来越高,并且快速幂适用场景也比较多并且相比朴素方法有了非常大提高。所以掌握快速算法已经是一名更合格工程师必备要求!...下面来详细看看快速算法吧!...现在你已经明白了快速幂是怎么回事,但你可能有点上头,还是给我讲了很多内容: ? 快速幂实现 至于快速幂已经懂了,我们该怎么实现这个算法呢? ?...,尤其是矩阵快速幂,会有着各种巧妙变形,不过跟数学有一些关系,这年头,不会点算法、不会点数学真的是举步维艰。

56910
领券