最近做了一下算法的一些练习,感觉基础薄弱了,只是用一些已经有的东西来完成练习如quickSort(c++使用的时候是sort(起始位置,终止位置,比较函数),这个需要加头文件),但是不知道怎么推出来,回顾了一下算法导论,也总结了一些经验,写了如下代码(这里是以升序来排列的,但是排序思想就是这样),供大家参考 //用于交换元素位置 void swap(int &a,int &b){ int temp = a; a = b; b = temp;} //划分以及元素的交换 int partiti…
原理介绍 通过一趟排序将要排序的数据分割成独立的两部分,其中一部分的所有数据都比另外一部分的所有数据都要小,然后再按此方法对这两部分数据分别进行快速排序,整个排序过程可以递归进行,以此达到整个数据变成有序序列. 具体实现 左右指针法 实现说明 代码实现 public static void sort1(int[] arr, int start, int end) { if (start >= end) { return; } int key = end; int left = start; in…