欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

java 實現(xiàn)最小二叉樹堆排序的實例

 更新時間:2017年09月22日 10:04:55   投稿:lqh  
這篇文章主要介紹了java 實現(xiàn)最小二叉樹堆排序的實例的相關資料,希望通過本文能幫助到大家,需要的朋友可以參考下

java 實現(xiàn)最小二叉堆排序的實例

寫在前面:

一覺醒來,我就突然有靈感了......

最小二叉堆定義:

二叉堆是完全二元樹或者是近似完全二元樹,最小二叉堆是父結點的鍵值總是小于或等于任何一個子節(jié)點的鍵值的堆堆。

存儲:

二叉堆一般用數(shù)組來表示。

根節(jié)點在數(shù)組中的位置是0,第n個位置的子節(jié)點分別在2n+1和 2n+2;

位置k的葉子的父節(jié)點位置為(k-1)/2;

實現(xiàn):

/** 
 * @description 元素添加到末尾,和它的父節(jié)點比,如果比它小就交換 
 * @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;//當前指向的數(shù)組元素位置 
    while(pointer!=0){ 
      int leafPointer = pointer;//葉子節(jié)點位置 
      pointer = (pointer-1)/2;//根節(jié)點位置 
      root = minBinaryHeap[pointer];//根節(jié)點 
      if(num>=minBinaryHeap[pointer]){//永遠把當前數(shù)組元素看成葉子與其根比較或者換位 
        break; 
      }//如果根比葉子大 就交換位置 
      minBinaryHeap[pointer] = num; 
      minBinaryHeap[leafPointer] = root; 
       
    } 
  } 
  return minBinaryHeap; 
   
} 

/*** 
 * 用隨機數(shù)測試二叉堆排序 
 * 測試10遍,強迫癥似的變態(tài)... 
 */ 
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(); 
  } 
} 


如有疑問請留言或者到本站社區(qū)交流討論,感謝閱讀,希望能幫助到大家,謝謝大家對本站的支持!

相關文章

  • 解讀線程池-Executors的newSingleThreadExecutor和newFixedThreadPool(1)區(qū)別

    解讀線程池-Executors的newSingleThreadExecutor和newFixedThreadPool(1

    這篇文章主要介紹了解讀線程池-Executors的newSingleThreadExecutor和newFixedThreadPool(1)區(qū)別,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教
    2024-08-08
  • SpringBoot Controller中的常用注解

    SpringBoot Controller中的常用注解

    這篇文章主要介紹了SpringBoot Controller中的常用注解,文章圍繞主題展開詳細的內容介紹,具有有一定的參考價值,需要的小伙伴可以參考一下
    2022-09-09
  • Java實現(xiàn)文件上傳與文件下載的示例代碼

    Java實現(xiàn)文件上傳與文件下載的示例代碼

    在開發(fā)中項目難免會遇到文件上傳和下載的情況,這篇文章主要為大家詳細介紹了Java中實現(xiàn)文件上傳與文件下載的示例代碼,希望對大家有所幫助
    2023-07-07
  • 詳解Maven JAR包沖突問題排查及解決方案

    詳解Maven JAR包沖突問題排查及解決方案

    這篇文章主要介紹了Maven JAR包沖突問題排查及解決方案,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2021-03-03
  • Logback動態(tài)修改日志級別的方法

    Logback動態(tài)修改日志級別的方法

    這篇文章主要介紹了Logback動態(tài)修改日志級別的方法,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2018-11-11
  • 微信公眾號開發(fā)之回復圖文消息java代碼

    微信公眾號開發(fā)之回復圖文消息java代碼

    這篇文章主要為大家詳細介紹了微信公眾號開發(fā)之回復圖文消息java代碼,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2018-03-03
  • Mybatis如何分割字符串

    Mybatis如何分割字符串

    這篇文章主要介紹了Mybatis如何分割字符串問題,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教
    2023-12-12
  • 使用mybatis報Invalid bound statement解決分析

    使用mybatis報Invalid bound statement解決分析

    這篇文章主要為大家介紹了使用mybatis報Invalid bound statement原因解決分析,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪
    2023-12-12
  • Spring的RestTemplata使用的具體方法

    Spring的RestTemplata使用的具體方法

    本篇文章主要介紹了Spring的RestTemplata使用的具體方法,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2018-01-01
  • springboot內置tomcat調優(yōu)并發(fā)線程數(shù)解析

    springboot內置tomcat調優(yōu)并發(fā)線程數(shù)解析

    這篇文章主要介紹了springboot內置tomcat調優(yōu)并發(fā)線程數(shù)解析,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2021-12-12

最新評論