堆排序 迷南。 2021-10-29 07:20 360阅读 0赞 什么是堆排序,堆排序能解决什么问题? 在排序的过程中,不能把进行排序的过程中,得一些信息保留下来吗?来加快排序的速度吗?答案是可以的。通过利用完全二叉堆的结构来保留信息。 堆的性质:每个节点都大于等于其左右孩子节点的值,称为大顶堆,或者每个节点的值都小于等于其左右孩子节点的值,称为小顶堆。 ki>=k2i ki<=k2i 1<=i<=n/2 ki>=k2i+1 ki<=k2i+1; 为什么i<=n/2呢?因为二叉树的一个性质,如果i = 1,则节点i是二叉树的根,无双亲,如果i>1,其双亲节点是i/2;那么对于有n个节点的二叉树而言,它的i值自然就是小于等于n/2. 如果当前i = 0,开始的,那么它的左孩子节点为i = 2i+1.右孩子节点位置为i = 2i+2. 堆排序过程: 1.构建堆(你可以构建大根堆或者小根堆)。 2.每次交换堆顶元素和最后一个元素,再维持从首元素最长度减1的位置的堆。 注:构建大根堆和构建小根堆一样的,把符号稍微改变就好了。 算法: //堆排序,1.先构建堆 2.再将堆顶与末尾交换,3.再重新调整堆,时间复杂度不论好坏都为 O(nlogn) public static void Heapsort(int[] arr){ //1.构建堆 for(int i = arr.length/2-1;i>=0;i--) //i起始从/2-1开始,是有原因的,这个元素位置都有左右子孩子 存在 { adjustHeap(arr,i,arr.length); // 调整从 i位置,到length长度的情况 } //for 交换堆顶元素,再调整 for(int j = arr.length-1;j>0;j--) // j-- 后变相让数组缩小了 { swap(arr,0,j); // 交换堆顶和最后一个位置的元素 adjustHeap(arr,0,j); // 把堆顶和j之间调整一下 } print(arr); } public static void print(int[] s){ for(int a:s){ System.out.print(a); } } /** * 调整大顶堆(仅是调整过程,建立在大顶堆已构建的基础上) * @param arr * @param i // 需要调整位置的根节点 * @param length // 调整数组的长度 */ public static void adjustHeap(int []arr,int i,int length){ //主要是调整堆函数 //temp当前传入根节点 int temp = arr[i]; for(int j = i*2+1;j<length;j = j*2+1) { // 从根节点的左右子节点开始调整 if(j+1<length && arr[j]<arr[j+1]) // 先比较左右子节点大小,因为是大根堆,找到大元素位置 j++; if(arr[j] > temp) { // 找到左右子节点较大元素,与根节点交换,并且,根节点的位置改变 arr[i] = arr[j]; i = j; // 去交换位置为根节点,再往下走,找到temp放下的合适位置 }else{ break; } } arr[i] = temp; // 插入 } /* 小顶堆排序尝试 */ public static void Heapsorts(int[] arr){ //1.构建堆 for(int i = arr.length/2-1;i>=0;i--) { adjustHeaps(arr,i,arr.length); } //for 交换堆顶元素,再调整 for(int j = arr.length-1;j>0;j--) { swap(arr,0,j); adjustHeaps(arr,0,j); } print(arr); } //小顶堆,堆排序 public static void adjustHeaps(int []arr,int i,int length){ //怎么调整呢? //把当前元素存下来 int temp = arr[i]; // for(int j = i*2+1;j<length;j = j*2+1) { if(j+1<length && arr[j]>arr[j+1]) j++; if(arr[j] < temp) { arr[i] = arr[j]; i = j; }else{ break; } } arr[i] = temp; } /* 交换元素 * @param arr * @param a * @param b */ public static void swap(int []arr,int a ,int b){ int temp=arr[a]; arr[a] = arr[b]; arr[b] = temp; }
相关 排序-堆排序 1.堆排序前言 前面博客中讲到简单选择排序,它在待排序的n个记录中选择一个最小的记录需要比较n-1次。本来这也可以理解,查找第一个数据需要比较这么多次是正常的,否则如何知 旧城等待,/ 2022年09月30日 06:45/ 0 赞/ 223 阅读
相关 【排序】堆排序 堆的定义 设有n个元素的序列 k1,k2,…,kn,当且仅当满足下述关系之一时,称之为堆。 ![图示][SouthEast] 解释:如果让满足以上条件的元素序列 (k 分手后的思念是犯贱/ 2022年06月18日 11:47/ 0 赞/ 259 阅读
相关 看懂堆排序——堆与堆排序(三) 看懂堆排序——堆与堆排序(三) 看懂堆排序——堆与堆排序(三) 堆排序的基本思想 代码详解 偏执的太偏执、/ 2022年05月25日 06:52/ 0 赞/ 275 阅读
相关 排序——堆排序 堆排序代码 include <iostream> using namespace std; include <stdio.h> in 墨蓝/ 2022年05月21日 12:05/ 0 赞/ 251 阅读
相关 堆排序 什么是堆排序,堆排序能解决什么问题? 在排序的过程中,不能把进行排序的过程中,得一些信息保留下来吗?来加快排序的速度吗?答案是可以的。通过利用完全二叉堆的结构来保留信息。 迷南。/ 2021年10月29日 07:20/ 0 赞/ 361 阅读
相关 堆和堆排序 堆排序 堆排序基本介绍 1. 堆排序是利用堆这种数据结构而设计的一种排序算法,堆排序是一种选择排序,它的最坏,最好,平均时间复 杂度均为 O(nlogn),它也 柔光的暖阳◎/ 2021年10月19日 21:12/ 0 赞/ 381 阅读
相关 堆排序 文章目录 一、堆排序介绍 二、如何进行堆排序 一、堆排序介绍 百度百科: 堆排序(Heapsort)是指利用堆积树 我会带着你远行/ 2021年10月18日 16:46/ 0 赞/ 347 阅读
相关 排序-堆排序 [2019独角兽企业重金招聘Python工程师标准>>> ][2019_Python_] ![hot3.png][] 在说明堆排序的过程前得先了解什么是堆: 先看下图(来源 清疚/ 2021年09月20日 03:22/ 0 赞/ 425 阅读
相关 堆排序 堆排序的特点是:在排序过程中,将待排序数组看成是一棵完全二叉树的顺序存储结构,利用完全二叉树中父结点和子结点之间的内在关系,在当前无序区中选择关键字最大(或最小) 不念不忘少年蓝@/ 2021年09月17日 00:16/ 0 赞/ 448 阅读
还没有评论,来说两句吧...