ホームページ >Java >&#&チュートリアル >Java最小バイナリツリーヒープソートの実装方法

Java最小バイナリツリーヒープソートの実装方法

黄舟
黄舟オリジナル
2017-09-22 11:14:141799ブラウズ

この記事では、Java による最小バイナリ ツリー ヒープ ソートの実装例に関する関連情報を中心に紹介します。必要な方の参考になれば幸いです

Java による最小バイナリ ツリー ヒープ ソートの実装例。 前回の記事:


目が覚めるとすぐに、突然インスピレーションが湧きました...


最小のバイナリ ヒープの定義:


バイナリ ヒープは、完全なバイナリ ツリー、またはほぼ完全なバイナリ ツリーであり、最小 Aバイナリ ヒープは、親ノードのキー値が常に子ノードのキー値以下であるヒープです。


ストレージ:


バイナリヒープは通常、配列で表されます。


配列内のルートノードの位置は0で、n番目の位置の子ノードはそれぞれ2n+1と2n+2にあります


位置kのリーフの親ノードの位置は(k -1)/2;


実装:


/** 
 * @description 元素添加到末尾,和它的父节点比,如果比它小就交换 
 * @param array 
 * 
 * @author LynnWong 
 */ 
private int[] getMinBinaryHeap(int[] array){ 
  int N = array.length; 
  int minBinaryHeap[] = new int[N]; 
  int root;//根的值 
  int heapSize = 0;//记录插入位置 
  for(int num : array){ 
    minBinaryHeap[heapSize]=num; 
    ++heapSize; 
    int pointer = heapSize-1;//当前指向的数组元素位置 
    while(pointer!=0){ 
      int leafPointer = pointer;//叶子节点位置 
      pointer = (pointer-1)/2;//根节点位置 
      root = minBinaryHeap[pointer];//根节点 
      if(num>=minBinaryHeap[pointer]){//永远把当前数组元素看成叶子与其根比较或者换位 
        break; 
      }//如果根比叶子大 就交换位置 
      minBinaryHeap[pointer] = num; 
      minBinaryHeap[leafPointer] = root; 
       
    } 
  } 
  return minBinaryHeap; 
   
}

/*** 
 * 用随机数测试二叉堆排序 
 * 测试10遍,强迫症似的变态... 
 */ 
public void text(){ 
  for(int i=0;i<10;i++){ 
    Random rnd = new Random();  
    int [] lala = {rnd.nextInt(6),rnd.nextInt(6),rnd.nextInt(6),rnd.nextInt(6),rnd.nextInt(6),rnd.nextInt(6)}; 
    System.out.print("输入:"); 
    for(int a : lala){ 
      System.out.print(a+" "); 
    } 
    System.out.println(); 
    int []array = this.getMinBinaryHeap(lala); 
    System.out.print("输出:"); 
    for(int a : array){ 
      System.out.print(a+" "); 
    } 
    System.out.println(); 
  } 
}

以上がJava最小バイナリツリーヒープソートの実装方法の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

声明:
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。