快速排序的C++版】的更多相关文章

在网上搜索算法的博客,发现一个比较悲剧的现象非常普遍: 原理讲不清,混乱 啰嗦 图和文对不上 不可用,甚至代码还出错 为了不误人子弟耽误时间,推荐看一些靠谱的资源,如[啊哈!算法]系列: https://www.cnblogs.com/ahalei/p/3568434.html 他是C语言实现,其实都是一样的. 我总结一个清晰不罗嗦版: 原理: 快速排序使用分而治之策略.下面描述递归步骤: 选择一个pivot支点值(在啊哈算法中叫“基准值”).我们将中间元素的值作为支点值,但是它也可以是任何值,…
1.冒泡排序是排序里面最简单的了,但性能也最差,数量小的时候还可以,数量一多,是非常慢的. 它的时间复杂度是O(n*n),空间复杂度是O(1) 代码如下,很好理解. public void bubbleSort(int[] arr){ int temp=0; for(int i=0;i<arr.length;i++){ for(int j=arr.length-1;j>0;j--){ if(arr[j-1]>arr[j]){ temp=arr[j-1]; arr[j-1]=arr[j];…
快速排序由于排序效率在同为O(N*logN)的几种排序方法中效率较高,因此经常被采用,再加上快速排序思想----分治法也确实实用,因此很多软件公司的笔试面试喜欢考这个. 快速排序是C.R.A.Hoare于1962年提出的一种划分交换排序.它采用了一种分治的策略,通常称其为分治法(Divide-and-ConquerMethod). *********************************** 分治法的基本思想: 1.先从数列中取出一个数作为基准数. 2.分区过程:将比这个数大的数全放到…
网上关于快速排序的算法原理和算法实现都比较多,不过java是实现并不多,而且部分实现很难理解,和思路有点不搭调.所以整理了这篇文章.如果有不妥之处还请建议.首先先复习一些基础.    1.算法概念.   快速排序(Quicksort)是对冒泡排序的一种改进.由C. A. R. Hoare在1962年提出.   2.算法思想.   通过一趟排序将要排序的数据分割成独立的两部分,其中一部分的所有数据都比另外一部分的所有数据都要小,然后再按此方法对这两部分数据分别进行快速排序,整个排序过程可以递归进行…
public class QuickSortTest{ //比较与交换 private static int partition(int[] source, int low, int hight) { int key = source[low]; while (low < hight) { while (low < hight && source[hight] >= key) { hight --; } source[low] = source[hight]; while…
int Partition(int a[], int low, int high) { int x = a[high];//将输入数组的最后一个数作为主元,用它来对数组进行划分 int i = low - 1;//i是最后一个小于主元的数的下标 for (int j = low; j < high; j++)//遍历下标由low到high-1的数 { if (a[j] < x)//如果数小于主元的话就将i向前挪动一个位置,并且交换j和i所分别指向的数 { int temp; i++; temp…
​ 算法原理:选一个数位基准,将序列分成两个部分,一边全是比它小序列,另一边全是比它大序列.然后再分别对比他小的序列和比再次进行基准分割.依次分割下去,得到一个有序的队列. 原理图示: ​编辑 ​编辑 ​编辑 ​编辑 ​编辑 ​编辑 ​编辑 ​编辑 ​编辑 ​编辑 ​编辑 ​编辑 ​编辑 算法步骤图示: 算法步骤 以序列首位数字位基准.下标为j的哨兵从右往左出发,找到一个比6小的数,停在该位置 ​编辑 下标为i的哨兵从左往右出发,找到一个比6大的数. ​编辑 交换两个哨兵的数字. ​编辑 继续该…
package com.whw.sortPractice; import java.util.Arrays; public class Sort { /** * 遍历一个数组 * @param sortArray */ public void outputArray(int[] sortArray) { for(int i = 0;i < sortArray.length;i++) { System.out.print(sortArray[i] + " "); } System.…
最近又翻看了一下数据结构(数据结构学渣). 以前总是看不懂,连冒泡和选择排序都要纠结半天,后来才慢慢有意识能区分开来. 当真的理解了快速排序之后,才觉得,这是个很赞的排序,很容易理解. 于是简单的,模仿c的做法,实现了javascript上的排序,目前只有冒泡.选择和快速排序.//不过貌似快速排序用到了传递的性质,也许我应该改改. function bubbleSort(arr){ console.log("冒泡排序:"); var len = arr.length; for(var…
学OI一年了,到现在联赛所需要的知识已经基本学完了.现在,有必要回过头来,总结总结自己一年来学到的知识以及得到的经验教训. 基础 语言基础 C++的语言基础啥的就略了吧. 算法复杂度分析 O:复杂度的上限. Ω:复杂度的下限. Θ:复杂度的上限与下限. STL与<algorithm> STL http://www.cplusplus.com/reference/stl 全称Standard Template Library(标准模板库). vector:动态数组. list:双向链表. set…