服装网站开发项目计划书电子工程王粟
news/
2025/9/29 17:51:04/
文章来源:
服装网站开发项目计划书,电子工程王粟,免费速建网站,深圳网站建设大概多少钱简介#xff1a; 快速排序也采用的是分而制之的思想。那么快速排序和归并排序的区别在什么地方呢#xff1f; 归并排序是将所有的元素拆分成一个个排好序的数组#xff0c;然后将这些数组再进行合并。 而快速排序虽然也是拆分#xff0c;但是拆分之后的操作是从数组中选出一…简介 快速排序也采用的是分而制之的思想。那么快速排序和归并排序的区别在什么地方呢 归并排序是将所有的元素拆分成一个个排好序的数组然后将这些数组再进行合并。 而快速排序虽然也是拆分但是拆分之后的操作是从数组中选出一个中间节点然后将数组分成两部分。 左边的部分小于中间节点右边的部分大于中间节点。 然后再分别处理左边的数组合右边的数组。
简介
快速排序也采用的是分而制之的思想。那么快速排序和归并排序的区别在什么地方呢
归并排序是将所有的元素拆分成一个个排好序的数组然后将这些数组再进行合并。
而快速排序虽然也是拆分但是拆分之后的操作是从数组中选出一个中间节点然后将数组分成两部分。
左边的部分小于中间节点右边的部分大于中间节点。
然后再分别处理左边的数组合右边的数组。
快速排序的例子
假如我们有一个数组29,10,14,37,20,25,44,15怎么对它进行快速排序呢
先看一个动画 我们再分析一下快速排序的步骤。
我们选择的是最左边的元素29作为中间点元素然后将数组分成三部分[0, 14, 15, 20, 25],[29],[44, 37]。
中间节点29已经排好序了不需要处理。
接下来我们再对左右分别进行快速排序。最后就得到了一个所有元素都排序的数组。
快速排序的java代码实现
我们先来看最核心的部分partition如何将数组以中间节点为界分成左右两部分呢
我们的最终结果是要将array分割成为三部分。
首先我们选择最左侧的元素作为中间节点的值。然后遍历数组中的其他元素。
假如mmiddleIndexk要遍历的元素index
考虑两种情况第一种情况是数组中的元素比中间节点的值要大。 这种情况下m不需要移动k1继续遍历即可。
第二种情况下数组中的元素比中间节点的值要小。 因为m左边的元素都要比中间节点的值要小所以这种情况下m需要1即右移一位。
现在m1位置的元素要么还没有进行比较要么就是比中间节点的值要大我们可以巧妙的将m1位置的元素和k位置的元素互换位置这样仍然能够保证m左侧的元素要比中间节点的值要小。
将上面的分析总结成java代码如下 private int partition(int[] array, int i, int j) {//选择最左侧的元素作为中心点,middleValue就是中心点的值int middleValue array[i];int middleIndex i;//从i1遍历整个数组for (int k i1; k j; k) {//如果数组元素小于middleValue表示middleIndex需要右移一位//右移之后我们需要将小于middleValue的array[k]移动到middleIndex的左边// 最简单的办法就是交换k和middleIndex的值if (array[k] middleValue) {middleIndex;//交换数组的两个元素swap(array, k , middleIndex);} //如果数组元素大于等于middleValue,则继续向后遍历,middleIndex值不变}// 最后将中心点放入middleIndex位置swap(array, i, middleIndex);return middleIndex;}
最后我们需要将最左侧的元素和中间节点应该在的index的元素互换下位置这样就将中间节点移动到了中间位置并返回中间位置。
再来看下divide的代码 public void doQuickSort(int[] array, int low, int high) {//递归的结束条件if (low high) {//找出中心节点的值int middleIndex partition(array, low, high);//数组分成了三部分// a[low..high] ~ a[low..m–1], pivot, a[m1..high]//递归遍历左侧部分doQuickSort(array, low, middleIndex-1);// a[m] 是中心节点已经排好序了不需要继续遍历//递归遍历右侧部分doQuickSort(array, middleIndex1, high);log.info(QuickSort之后的数组:{},array);}}
divide的代码就很简单了找到中间节点的位置之后我们再分别遍历数组的左右两边即可。最后得到排好序的数组。
随机快速排序的java实现
上面的例子中我们的中间节点的选择是数组的最左元素为了保证排序的效率我们可以从数组中随机选择一个元素来作为中间节点。 private int partition(int[] array, int i, int j) {//随机选择一个元素作为中心点,middleValue就是中心点的值int randomIndexinew Random().nextInt(j-i);log.info(randomIndex:{},randomIndex);//首先将randomIndex的值和i互换位置,就可以复用QuickSort的逻辑swap(array, i , randomIndex);int middleValue array[i];int middleIndex i;//从i遍历整个数组for (int k i1; k j; k) {//如果数组元素小于middleValue表示middleIndex需要右移一位//右移之后我们需要将小于middleValue的array[k]移动到middleIndex的左边// 最简单的办法就是交换k和middleIndex的值if (array[k] middleValue) {middleIndex;//交换数组的两个元素swap(array, k , middleIndex);} //如果数组元素大于等于middleValue,则继续向后遍历,middleIndex值不变}// 最后将中心点放入middleIndex位置swap(array, i, middleIndex);return middleIndex;}
上面的代码我们在分区的时候先选择出一个随机的节点然后将这个随机的节点和最左侧的元素交换位置后面的代码就可以重用上面的QuickSort的代码逻辑了。
快速排序的时间复杂度
从上面的分析我们可以看出每次分区的时间复杂度应该是O(N)而divide又近似二分法所以总的时间复杂度是O(N logN)。 原文链接 本文为阿里云原创内容未经允许不得转载。
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/922079.shtml
如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!