(6)排序算法——堆排序
来源:互联网 发布:青岛seo排名软件 编辑:程序博客网 时间:2024/05/16 09:02
时间复杂度为O(n*logn)
public class HeapSort { /** Heap sort method */ public static <E extends Comparable> void heapSort(E[] list) { // Create a Heap of integers Heap<E> heap = new Heap<E>(); // Add elements to the heap for (int i = 0; i < list.length; i++) heap.add(list[i]); // Remove elements from the heap for (int i = list.length - 1; i >= 0; i--) list[i] = heap.remove(); } /** A test method */ public static void main(String[] args) { Integer[] list = {2, 3, 2, 5, 6, 1, -2, 3, 14, 12}; heapSort(list); for (int i = 0; i < list.length; i++) System.out.print(list[i] + " "); }}class Heap<E extends Comparable> { private java.util.ArrayList<E> list = new java.util.ArrayList<E>(); /** Create a default heap */ public Heap() { } /** Create a heap from an array of objects */ public Heap(E[] objects) { for (int i = 0; i < objects.length; i++) add(objects[i]); } /** Add a new object into the heap */ public void add(E newObject) { list.add(newObject); // Append to the heap int currentIndex = list.size() - 1; // The index of the last node while (currentIndex > 0) { int parentIndex = (currentIndex - 1) / 2; // Swap if the current object is greater than its parent if (list.get(currentIndex).compareTo( list.get(parentIndex)) > 0) { E temp = list.get(currentIndex); list.set(currentIndex, list.get(parentIndex)); list.set(parentIndex, temp); } else break; // the tree is a heap now currentIndex = parentIndex; } } /** Remove the root from the heap */ public E remove() { if (list.size() == 0) return null; E removedObject = list.get(0); list.set(0, list.get(list.size() - 1)); list.remove(list.size() - 1); int currentIndex = 0; while (currentIndex < list.size()) { int leftChildIndex = 2 * currentIndex + 1; int rightChildIndex = 2 * currentIndex + 2; // Find the maximum between two children if (leftChildIndex >= list.size()) break; // The tree is a heap int maxIndex = leftChildIndex; if (rightChildIndex < list.size()) { if (list.get(maxIndex).compareTo( list.get(rightChildIndex)) < 0) { maxIndex = rightChildIndex; } } // Swap if the current node is less than the maximum if (list.get(currentIndex).compareTo( list.get(maxIndex)) < 0) { E temp = list.get(maxIndex); list.set(maxIndex, list.get(currentIndex)); list.set(currentIndex, temp); currentIndex = maxIndex; } else break; // The tree is a heap } return removedObject; } /** Get the number of nodes in the tree */ public int getSize() { return list.size(); }}
0 0
- 排序算法6——堆排序
- 排序算法—堆排序
- 排序算法—堆和堆排序
- (6)排序算法——堆排序
- 排序算法——堆排序算法
- 排序算法——堆排序
- 排序算法——堆排序
- 常用排序算法——堆排序
- 排序算法——堆排序
- 排序算法——堆排序
- 算法——排序之堆排序
- 排序算法——堆排序
- 排序算法——堆排序
- 排序算法——堆排序
- 排序算法系列——堆排序
- 【排序算法】——堆排序
- 经典排序算法——堆排序
- 排序算法——堆排序
- 问题:XMLHttpRequest cannot load file~~Origin 'null' is therefore not allowed access
- Netty精粹之TCP粘包拆包问题
- IP之于游戏
- 集成学习
- STM32——流水灯
- (6)排序算法——堆排序
- markdown临时记录
- MFC获取系统时间
- unresolved symbol @__security_check_cookie
- Android网络编程使用HttpClient访问web站点
- Linux内核分析实验四
- 为什么谷歌越来越牛逼,而百度却...
- 广度/宽度 优化搜索
- 颠倒的价牌--蓝桥杯