[转帖]简单_堆排序算法_Android, Python及开发编程讨论区_Weblogic技术|Tuxedo技术|中间件技术|Oracle论坛|JAVA论坛|Linux/Unix技术|hadoop论坛_联动北方技术论坛  
网站首页 | 关于我们 | 服务中心 | 经验交流 | 公司荣誉 | 成功案例 | 合作伙伴 | 联系我们 |
联动北方-国内领先的云技术服务提供商
»  游客             当前位置:  论坛首页 »  自由讨论区 »  Android, Python及开发编程讨论区 »
总帖数
1
每页帖数
101/1页1
返回列表
0
发起投票  发起投票 发新帖子
查看: 4364 | 回复: 0   主题: [转帖]简单_堆排序算法        下一篇 
fozhyn
注册用户
等级:上士
经验:317
发帖:101
精华:0
注册:2011-10-18
状态:离线
发送短消息息给fozhyn 加好友    发送短消息息给fozhyn 发消息
发表于: IP:您无权察看 2011-10-19 15:25:48 | [全部帖] [楼主帖] 楼主

Java代码   北京联动北方科技有限公司


package sunfa.sort;
import java.util.Arrays;
import java.util.Comparator;
import java.util.Random;
public class HeapSort {
      public static void main(String[] args) {
            int n = 20;
            Random ran = new Random();
            int[] arr = new int[n];
            Heap<Integer> heap = new Heap<Integer>(n, new Comparator<Integer>() {
                  public int compare(Integer o1, Integer o2) {
                        return o2 - o1;
                  }
            });
            for (int i = 0; i < n; i++) {
                  int o = ran.nextInt(100);
                  arr[i] = o;
                  heap.add(o);
            }
            System.out.println(Arrays.toString(arr));
            // System.out.println(Arrays.toString(heap.getHeap()));
            // System.out.println(heap.getHeap()[heap.count()]);
            // heap.swap(heap.getHeap(), 1, heap.count());
            // System.out.println("swap:" + Arrays.toString(heap.getHeap()));
            // heap.heapify(1, heap.count());
            System.out.println(Arrays.toString(heap.getHeap()));
            System.out.println("堆排序:");
            int last = heap.count();
            while (last - 1 > 1) {
                  heap.swap(heap.getHeap(), 1, last--);
                  if (last - 1 > 1) {
                        heap.heapify(1, last);
                  }
                  System.out.println("堆化后:" + ",last:" + last  
                    + Arrays.toString(heap.getHeap()));
            }
      }
}
class Heap<E> {
private Object[] heap;
private int size;
Comparator<E> comp;
public Object[] getHeap() {
      return heap;
}
public int count() {
      return size;
}
public Heap(int n, Comparator<E> c) {
      if (n < 0)
      throw new IllegalArgumentException("n:" + n);
      comp = c;
      heap = new Object[n];
}
public void add(E e) {
      if (size + 1 == heap.length)
      heap = Arrays.copyOf(heap, heap.length << 1);
      heap[++size] = e;
      fixUp(size);
}
private void fixUp(int k) {
      while (k > 1) {
            int p = k >>> 1;
            if (compare((E) heap[k], (E) heap[p]) > 0)
            break;
            swap((E[]) heap, k, p);
            k = p;
      }
}
public void swap(Object[] e, int a, int b) {
      Object t = e[a];
      e[a] = e[b];
      e[b] = t;
}
private int compare(E t1, E t2) {
      return comp == null ? (((Comparable<E>) t1).compareTo(t2)) : (comp
      .compare(t1, t2));
}
private void fixDown(int k) {
      int j;
      while ((j = k << 1) <= size) {
            if (j < size && compare((E) heap[j], (E) heap[j + 1]) > 0)
            j++;
            if (compare((E) heap[k], (E) heap[j + 1]) < 0)
            break;
            swap((E[]) heap, k, j);
            k = j;
      }
}
public void heapify(int a, int b) {
      for (int i = b; i >= a; i--) {
            fixUp(i);
      }
}
}




赞(0)    操作        顶端 
总帖数
1
每页帖数
101/1页1
返回列表
发新帖子
请输入验证码: 点击刷新验证码
您需要登录后才可以回帖 登录 | 注册
技术讨论