快速排序排与堆排序
2021-04-09 13:28
标签:adjust 第一个 start break 快速排序 ram length sys param 最近练习时,觉得有些生疏,所以加强锻炼。 快速排序(从小到大排序,升序) 堆排序(大顶堆,从大到小排序,降序) 快速排序排与堆排序 标签:adjust 第一个 start break 快速排序 ram length sys param 原文地址:https://www.cnblogs.com/yishanchuan/p/13373979.html引子
具体实现
public class QuickSort{
public static void swap(int[] arr, int i, int j){
int temp = arr[i];
arr[i] = arr[j];
arr[j] = temp;
}
public static void sort(int[] arr, int startIndex, int endIndex){
if(arr != null && arr.length > 0){
int start = startIndex, end = endIndex;
// 默认以第一个作为基准
int target = arr[startIndex];
// 外循环,两头往中间循环,两边相遇时结束
while(start target){
swap(arr,start, end);
break;
}else{
start++;
}
}
}
//经过前面两个循环,start和end相遇,如果start到startIndex还有元素,对这部分进行排序
if((start-1) > startIndex){
sort(arr,startIndex,start-1);
}
//同理,如果end到endIndex中还有元素,对这部分进行排序
if((end+1)
class HeapSort {
public static void main(String[] args) {
// int[] arr = {5, 1, 7, 3, 1, 6, 9, 4};
int[] arr = {16, 7, 3, 20, 17, 8};
heapSort(arr);
for (int i : arr) {
System.out.print(i + " ");
}
}
/**
* 创建堆,
* @param arr 待排序列
*/
private static void heapSort(int[] arr) {
//创建堆
for (int i = (arr.length - 1) / 2; i >= 0; i--) {
//从第一个非叶子结点从下至上,从右至左调整结构
adjustHeap(arr, i, arr.length);
}
//调整堆结构+交换堆顶元素与末尾元素
for (int i = arr.length - 1; i > 0; i--) {
//将堆顶元素与末尾元素进行交换
int temp = arr[i];
arr[i] = arr[0];
arr[0] = temp;
//重新对堆进行调整
adjustHeap(arr, 0, i);
}
}
/**
* 调整堆
* @param arr 待排序列
* @param parent 父节点
* @param length 待排序列尾元素索引
*/
private static void adjustHeap(int[] arr, int parent, int length) {
//将temp作为父节点
int temp = arr[parent];
//左孩子
int lChild = 2 * parent + 1;
while (lChild arr[rChild]) {
lChild++;
}
// 如果父结点的值已经大于孩子结点的值,则直接结束
if (temp
上一篇:Java泛型相关知识