堆排序算法 java 实现
堆排序算法 java 实现
算法概念
堆排序(HeapSort)是指利用堆积树(堆)这种数据结构所设计的一种排序算法,可以利用数组的特点快速定位指定索引的元素。堆排序是不稳定的排序方法,辅助空间为O(1), 最坏时间复杂度为O(nlog2n) ,堆排序的堆序的平均性能较接近于最坏性能。
算法思想
建立最小堆;
取出堆顶元素,顺序放到待排序数组中;将堆底元素放到堆顶,并重新调整堆;
重复步骤 2 ,直至堆中所有元素全部取完;
参考的两篇文章都是将堆顶元素和堆底元素互换,最后存放堆的数组就变成了有序数组。
- 建立最大堆;
- 将堆顶元素和堆底元素互换;重新调整除堆底有序元素外的堆;
- 重复步骤 2 ,直至堆中全部元素都变有序;
算法实现
package com.lygedi.sort;
import org.apache.commons.lang.ArrayUtils;
import org.apache.commons.lang.StringUtils;
public class HeapSort {
public static void main(String[] args) {
int a[] = { 49, 38, 65, 9, 76, 13, 27, 49, 8, 34, 12, 64, 49, 56, 2, 51, 13, 5, 4, 62, 99, 98, 54, 56, 17, 17,
18, 23, 34, 56, 15, 35, 25, 53, 51 };
int[] b = a.clone();
HeapSort hs = new HeapSort();
hs.sortByMinHeapClass(a);
hs.sortByOneMothed(b);
System.out.println(a.length);
for (int i = 0; i < a.length; i++)
System.out.println(Integer.toString(i) + "-" + a[i] + "--" + b[i]);
}
public void sortByMinHeapClass(int[] list) {
MinHeap mh = new MinHeap(list);
System.out.println(mh);
for (int i = 0; i < list.length; i++) {
list[i] = mh.pushTop();
}
}
public void sortByOneMothed(int[] list){
for(int i = list.length-1; i>=0; i--){
initMaxHeap(list,0,i);
swap(list,0,i);
}
}
private void initMaxHeap(int[] list,int startIndex,int stopIndex){
int leftChild, rightChild;
boolean isChanged = false;
for(int i=startIndex;i<=stopIndex;i++){
leftChild = i*2 + 1;
rightChild = i*2 + 2;
if(leftChild<=stopIndex && list[i]<list[leftChild]){
swap(list,i,leftChild);
isChanged = true;
}
if(rightChild<=stopIndex && list[i]<list[rightChild]){
swap(list,i,rightChild);
isChanged = true;
}
if(i>startIndex && isChanged){
i = (i - 1)/2 - 1;
isChanged = false;
}
}
}
private void swap(int[] list,int i,int j){
int temp = list[i];
list[i] = list[j];
list[j] = temp;
}
}
class MinHeap {
private int[] heap;
public MinHeap(int[] list) {
heap = list;
fixHeap();
}
public int pushTop() {
int top = heap[0];
int tail = heap[heap.length - 1];
if (heap.length > 1) {
int[] newheap = ArrayUtils.subarray(heap, 0, heap.length - 1);
newheap[0] = tail;
heap = newheap;
fixHeap();
}
return top;
}
private void swap(int[] list,int i,int j){
int temp = list[i];
list[i] = list[j];
list[j] = temp;
}
private void fixHeap() {
int leftChild, rightChild;
boolean isChanged = false;
for (int i = 0; i < heap.length; i++) {
leftChild = i * 2 + 1;
rightChild = i * 2 + 2;
if (leftChild <= heap.length - 1 && heap[i] > heap[leftChild]) {
swap(heap,i,leftChild);
isChanged = true;
}
if (rightChild <= heap.length - 1 && heap[i] > heap[rightChild]) {
swap(heap,i,rightChild);
isChanged = true;
}
//如果子节点进行了调整,则要对父节点重新进行调整
if (isChanged && i > 0) {
i = (i - 1) / 2 - 1;
isChanged = false;
}
}
}
public String toString() {
StringBuilder sb = new StringBuilder();
int count = heap.length;
int grade = (int) Math.ceil(java.lang.StrictMath.pow(count, 1.0 / 2));
String padding = "**";
int index = 0;
for (int i = 1; i <= grade; i++) {
int padNum = (int)Math.pow(2, grade-i+1)-1;
String gradePadding = StringUtils.repeat(padding, padNum);
for (int j = 1; j <= Math.pow(2, i - 1); j++) {
if (index < count) {
sb.append(gradePadding);
String paddingInt = StringUtils.leftPad(Integer.toString(heap[index]), padding.length(), "*");
sb.append(paddingInt);
index++;
sb.append(gradePadding);
sb.append(padding);
}
}
sb.append("\r\n\r\n\r\n");
}
return sb.toString();
}
}
堆排序算法 java 实现的更多相关文章
- 排序系列 之 堆排序算法 —— Java实现
基本概念: 二叉堆是完全二叉树或者是近似完全二叉树. 当父结点的键值总是大于或等于任何一个子节点的键值时为最大堆. 当父结点的键值总是小于或等于任何一个子节点的键值时为最小堆. 一般将二叉堆简称 ...
- 堆排序算法(Java实现)
将待排序的序列构造成一个大顶堆(从大到小排要构造成小顶堆).此时,整个序列的最大值就是堆顶的根节点,将他和末尾元素交换,然后将剩余的length-1个节点序列重新构造成新的堆.重复执行,便能得到一个有 ...
- 算法-java代码实现堆排序
堆排序 第7节 堆排序练习题 对于一个int数组,请编写一个堆排序算法,对数组元素排序. 给定一个int数组A及数组的大小n,请返回排序后的数组. 测试样例: [1,2,3,5,2,3],6 [1,2 ...
- 堆排序算法的java实现
堆积排序(Heapsort)是指利用堆积树(堆)这种数据结构所设计的一种排序算法,可以利用数组的特点快速定位指定索引的元素.堆排序是不稳定的排序方法,辅助空间为O(1), 最坏时间复杂度为O ...
- 必须知道的八大种排序算法【java实现】(三) 归并排序算法、堆排序算法详解
一.归并排序算法 基本思想: 归并(Merge)排序法是将两个(或两个以上)有序表合并成一个新的有序表,即把待排序序列分为若干个子序列,每个子序列是有序的.然后再把有序子序列合并为整体有序序列. 归并 ...
- 排序算法入门之堆排序(Java实现)
堆排序 在学习了二叉堆(优先队列)以后,我们来看看堆排序.堆排序总的运行时间为O(NlonN). 堆的概念 堆是以数组作为存储结构. 可以看出,它们满足以下规律: 设当前元素在数组中以R[i]表示,那 ...
- 【java排序】 归并排序算法、堆排序算法
一.归并排序算法 基本思想: 归并(Merge)排序法是将两个(或两个以上)有序表合并成一个新的有序表,即把待排序序列分为若干个子序列,每个子序列是有序的.然后再把有序子序列合并为整体有序序列. 归并 ...
- 八大排序算法Java实现
本文对常见的排序算法进行了总结. 常见排序算法如下: 直接插入排序 希尔排序 简单选择排序 堆排序 冒泡排序 快速排序 归并排序 基数排序 它们都属于内部排序,也就是只考虑数据量较小仅需要使用内存的排 ...
- 排序算法(Java实现)
这几天一直在看严蔚敏老师的那本<数据结构>那本书.之前第一次学懵懵逼逼,当再次看的时候,发觉写的是非常详细,非常的好. 那就把相关的排序算法用我熟悉的Java语言记录下来了.以下排序算法是 ...
随机推荐
- jQuery插件入门
一:导言 有些WEB开发者,会引用一个JQuery类库,然后在网页上写一写("#"),("#"),("."),写了几年就对别人说非常熟悉JQ ...
- css3动态旋转魔方练习
图片素材: html部分: <!DOCTYPE html><html><head> <meta charset="utf-8" /> ...
- [转]Oracle数据块体系的详细介绍
数据块概述Oracle对数据库数据文件(datafile)中的存储空间进行管理的单位是数据块(data block).数据块是数据库中最小的(逻辑)数据单位.与数据块对应的,所有数据在操作系统级的最小 ...
- 安卓中級教程(5):ScrollView與refreshable之間的設置
設置向下拉動更新. package com.mycompany.Scroll_test; import android.app.*; import android.os.*; import andro ...
- myeclipse项目上出现红色叹号
右键选中项目:build path→configure build path (由于的我是在问题解决之后发表的博客,所以jar包上面的红色叉子不见了,只要选中红色的jar包,然后选择‘Remove’按 ...
- 【iCore3 双核心板】例程三十六:DAC实验——输出直流电压
实验指导书及代码包下载: http://pan.baidu.com/s/1bRVnzS iCore3 购买链接: https://item.taobao.com/item.htm?id=5242294 ...
- JavaScript + PHP 实现刷新继续保持倒计时的按钮
场景:发送一个验证码到手机,当验证码发出时,会提示隔 1 分钟之后可以再次发送.通常有这几种方式防止恶意请求,一是再次发送之前需要输入验证码,二是在指定的时间间隔之内不能再次发送. 有些网站在 1 分 ...
- .NET Framework基础知识总结
之前给大家总结了java的面试几次技巧总结,同学们看了觉得还是不错,能够得到大家的认可,感觉还是挺不错的.现在又有同学来想小编索要.NET面试的总结了,好吧.谁让小编这么好呢!以下是.NET面试之框架 ...
- NDK中可靠的获取JNIEnv*的方法
使用NDK时,几乎任何方法都需要一个JNIEnv来调用.这个类是和线程相关的,如何可靠的获取它? 首先,作为NDK的so,必然有一个地方是由android系统调用的,这个调用将带来一个JNIEnv参数 ...
- Repeater嵌套Repeater并取得嵌套Repeater里面的控件
前台代码: <asp:Repeater ID="RepeaterScene" runat="server" OnItemDataBound=&quo ...