# scala数据结构和算法-08-堆排序

412人阅读 评论(0)

1．父结点的键值总是大于或等于（小于或等于）任何一个子节点的键值。

2．每个结点的左子树和右子树都是一个二叉堆（都是最大堆或最小堆）。

## 堆的存储

package data

import scala.collection.mutable.ListBuffer

object HeapSort {
def buildHeap[T](comparator:(T,T)=>Boolean)(source:ListBuffer[T],parent:Int){
if(left(parent)>=source.length){
return
}else{
buildHeap(comparator)(source,left(parent));
}
if(right(parent)>=source.length){
return
}else{
buildHeap(comparator)(source,right(parent));
}
if(comparator(source(left(parent)),source(parent))
&&comparator(source(right(parent)),source(parent))){
if(comparator(source(left(parent)),source(right(parent)))){
val p=source(parent)
source(parent)=source(left(parent))
source(left(parent))=p
buildHeap(comparator)(source,left(parent))
}else{
val p=source(parent)
source(parent)=source(right(parent))
source(right(parent))=p
buildHeap(comparator)(source,right(parent))
}
}else if(comparator(source(left(parent)),source(parent))){
val p=source(parent)
source(parent)=source(left(parent))
source(left(parent))=p
buildHeap(comparator)(source,left(parent))
}else if(comparator(source(right(parent)),source(parent))){
val p=source(parent)
source(parent)=source(right(parent))
source(right(parent))=p
buildHeap(comparator)(source,right(parent))
}

}

def left(parent:Int)={
parent*2+1
}

def right(parent:Int)={
parent*2+2
}

def heapfye[T](comparator:(T,T)=>Boolean)(source:ListBuffer[T],parent:Int,rightIndex:Int){
if(left(parent)>rightIndex){
return
}
/*if(right(parent)>rightIndex){
return
}*/
if(left(parent)<=rightIndex&&right(parent)>rightIndex){
if(comparator(source(left(parent)),source(parent))){
val p=source(parent)
source(parent)=source(left(parent))
source(left(parent))=p
heapfye(comparator)(source,left(parent),rightIndex)
}
}else{
if(comparator(source(left(parent)),source(parent))
&&comparator(source(right(parent)),source(parent))){
if(comparator(source(left(parent)),source(right(parent)))){
val p=source(parent)
source(parent)=source(left(parent))
source(left(parent))=p
heapfye(comparator)(source,left(parent),rightIndex)
}else{
val p=source(parent)
source(parent)=source(right(parent))
source(right(parent))=p
heapfye(comparator)(source,right(parent),rightIndex)
}
}else if(comparator(source(left(parent)),source(parent))){
val p=source(parent)
source(parent)=source(left(parent))
source(left(parent))=p
heapfye(comparator)(source,left(parent),rightIndex)
}else if(comparator(source(right(parent)),source(parent))){
val p=source(parent)
source(parent)=source(right(parent))
source(right(parent))=p
heapfye(comparator)(source,right(parent),rightIndex)
}
}
}

def heapSort[T](comparator:(T,T)=>Boolean)(source:ListBuffer[T],rightIndex:Int):ListBuffer[T]={
for(i<-(1 until source.length).reverse){
val tmp=source(i)
source(i)=source(0)
source(0)=tmp;
heapfye(comparator)(source,0,i-1)
}
source
}
def main(args: Array[String]): Unit = {
val source=ListBuffer(3,1,4,9,5,8,7)
buildHeap[Int](_>_)(source,0)
println(source.mkString(","))
println(heapSort[Int](_>_)(source,source.length-1).mkString(","))
}
}

0
0

* 以上用户言论只代表其个人观点，不代表CSDN网站的观点或立场
个人资料
• 访问：597939次
• 积分：8620
• 等级：
• 排名：第2214名
• 原创：289篇
• 转载：332篇
• 译文：1篇
• 评论：122条
博客专栏
 fix协议实战 文章：35篇 阅读：33855
 源码阅读心得 文章：0篇 阅读：0
 java面试题 文章：32篇 阅读：17609
 设计模式 文章：23篇 阅读：5006
 python数据结构和算法 文章：7篇 阅读：1115
 微软100题scala.java , python,c,c++版 文章：27篇 阅读：8627
 scala数据结构和算法 文章：10篇 阅读：2805
文章分类
评论排行
最新评论