千锋教育-做有情怀、有良心、有品质的职业教育机构

400-811-9990
手机站
千锋教育

千锋学习站 | 随时随地免费学

千锋教育

扫一扫进入千锋手机站

领取全套视频
千锋教育

关注千锋学习站小程序
随时随地免费学习课程

上海
  • 北京
  • 郑州
  • 武汉
  • 成都
  • 西安
  • 沈阳
  • 广州
  • 南京
  • 深圳
  • 大连
  • 青岛
  • 杭州
  • 重庆
当前位置:杭州千锋IT培训  >  行业资讯  >  千锋杭州大数据培训教程分享:堆排序

千锋杭州大数据培训教程分享:堆排序

来源:千锋教育
发布人:千锋老师
时间: 2018-10-10 16:40:00

  经过这一个月的学习,我感觉学到了不少关于以后发展的东西,之前因为学过Java基础,所以这一阶段对我来说并不是很困难,但经过再一次的学习,使我对java基础有了更深的了解。在之前有一些东西是死记硬背的,只会套着用,而现在能够灵活使用了。老师闫哥的编程思想也对我影响很大,使我现在的编程比以前更加成熟,对知识的把握更加系统。在第一阶段中,我们学习了八大排序中的选择排序和冒泡排序,之后我又自己学习了堆排序。接下来我向大家分享一下我所理解的堆排序。

  一、什么是堆排序

  堆排序是将数组看做一个完全二叉树(附录里有二叉树的解释),具有以下的性质:

  1)每个节点的值都大于子节点的值,叫做大顶堆。

1

  2)每个节点的值都小于子节点的值,叫做小顶堆。

2

  二、堆排序的实现原理

  大顶堆是将数组按照升序的方式进行排序。其原理在于:

  1)从最后一个根节点开始,比较父节点和两个子节点的值,如果子节点的值大于父节点,则交换两点的数值,否则不交换。

  2)从最后一个根节点依次比较到顶点 ,也就是上图0节点的位置。这样进行一轮比较之后,得到的0节点的数值就是该数组中最大的数值。

  3)再将0节点的数值与该数组最后一个子节点的数值进行交换。这是最后一个子节点位置上的值便是该数组中最大的值。

  4)这时,把数组的倒数第二个子节点当做数组的结尾,再次将0节点作为父节点进行大顶堆操作,这样重复到数组的结尾为1节点,数组排序完成。

  5)将数组输出可以看到该数组变为一个升序的数组。

  而小顶堆则与大顶堆正好相反。

  三、代码实现:

  package JavaDay_13

  publc class Heapsort {public static void main(String[] args) {int[] arr ={1,5,6,8,7,2,3,4,9,4,15,12}; //创建一个数组

  heapSort(arr); //调用heapSort方法进行第一次排序,选出最大值放在0节点

  for(int i=0;i<arr.length;i++){ //将arr数组输出

  System.out.print(arr+" ");}}

  public static void heapSort(int[]arr){int n= arr.length-1;

  for(int i=n/2-1;i>=0;i++){ //从最后一个根节点开始,直到0节点位置heapAdjust(arr,i,n); // 传入参数arr数组,父节点 i ,数组长度n }

  for(int i=n;i>0;i--) { //从最后一个节点开始,到取到倒数第二个节点swap(arr,i); //调用方法,将此时的 i 与arr数组的第一个值交换

  heapAdjust(arr,0,i-1); //再次构建大顶堆}}

  public static void heapAdjust(int[] arr,int parent,int length) {int temp = arr[parent]; //设置一个初始值记录arr[parent]的数值

  for(int i=parent*2+1;i<=length;i=i*2+1) {// i为父节点的左节点,每次循环结束后,i节点成为父节点,i迭代为自己之前的数的左节点

  if(i<length && arr<arr[i+1]){i++; //如果i的左节点小于右节点,则i+1变为右节点}

  if(temp>arr) {break; // 如果左右节点中较大的值小于父节点,则跳出 }

  arr[parent] = arr; //让父节点的值变为i节点的值parent = i; //此时父节点变为i;}

  arr[parent] = temp; // 将刚刚得到的父节点赋值给新位置}

  public static void swap(int[] arr,int i) { //将数组arr中的i的值与0交int temp = arr[0]; arr[0] = arr;arr = temp;}}

  在计算机科学中,二叉树是每个结点最多有两个子树的树结构。通常子树被称作"左子树"和"右子树"。

  完全二叉树--若设二叉树的高度为h,除第 h 层外,其它各层 (1~h-1) 的结点数都达到最大个数,第 h 层有叶子结点,并且叶子结点都是从左到右依次排布,这就是完全二叉树。

  以上是堆排序相关知识点,以此纪念这段时间奋发图强的自己。不积跬步无以至千里,不积小流无以成江海,积累成就未来,以此自勉!

  大数据的前景是毋庸置疑的,如果想进入这个"吸金"的领域,选择千锋大数据培训机构学习是明智之举。千锋大数据培训课程内容不断更新升级,让学生学到更加贴合企业需求和项目应用的一些高端技术,势必能进一步提高学生竞争力,为学员的高薪就业以及未来的发展保驾护航!

声明:本站稿件版权均属千锋教育所有,未经许可不得擅自转载。

猜你喜欢LIKE

5种方法教你如何利用新媒体进行内容营销和产品推广

2023-04-25

编程培训一般多少钱?怎么选择编程培训学校?

2023-03-07

前端开发培训需要多长时间?去哪里培训好

2023-02-16

最新文章NEW

Java培训一般需要多久?课程结束学不会怎么办?

2023-03-13

ui设计分为哪几种?分别有什么特点

2023-02-28

计算机学前端好还是后端好?需不需要去培训

2023-02-16

相关推荐HOT

更多>>

快速通道 更多>>

最新开班信息 更多>>

网友热搜 更多>>