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

java哈夫曼樹實例代碼

 更新時間:2020年04月28日 09:04:32   作者:稀飯粥95  
這篇文章主要為大家介紹了java哈夫曼樹實例代碼,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下

本文實例為大家分享了哈夫曼樹java代碼,供大家參考,具體內(nèi)容如下

package boom;
 
import java.util.ArrayDeque;
import java.util.ArrayList;
import java.util.Collections;
import java.util.List;
import java.util.Queue;
 
class Node<T> implements Comparable<Node<T>>{
 private T data;
 private int weight;
 private Node<T> left;
 private Node<T> right;
  
 public Node (T data,int weight){
  this.data = data;
  this.weight = weight;
 }
  
 public int compareTo(Node<T> other) {
  if(this.weight > other.getWeight()){
   return -1;
  }if(this.weight < other.getWeight()){
   return 1;
  }
  return 0;
 }
 
 public T getData() {
  return data;
 }
 
 public void setData(T data) {
  this.data = data;
 }
 
 public int getWeight() {
  return weight;
 }
 
 public void setWeight(int weight) {
  this.weight = weight;
 }
 
 public Node<T> getLeft() {
  return left;
 }
 
 public void setLeft(Node<T> left) {
  this.left = left;
 }
 
 public Node<T> getRight() {
  return right;
 }
 
 public void setRight(Node<T> right) {
  this.right = right;
 } 
  
 public String toString(){ 
  return "data:"+this.data+";weight:"+this.weight; 
 } 
}
 
public class huffuman<T> {
 static <T> Node<T> create(List<Node<T>> nodes){
  while(nodes.size()>1){
   Collections.sort(nodes); 
   Node<T> left = nodes.get(nodes.size()-1);
   Node<T> right = nodes.get(nodes.size()-2);
   Node<T> parent = new Node<T>(null,left.getWeight()+right.getWeight());
   parent.setRight(right);
   parent.setLeft(left);
   nodes.remove(left);
   nodes.remove(right);
   nodes.add(parent);
  }
  return nodes.get(0); 
 }
 static<T> List<Node<T>> breadth(Node<T> root){
  List<Node<T>> list = new ArrayList<Node<T>>();
  Queue<Node<T>> queue = new ArrayDeque<Node<T>>();
  queue.offer(root);
  while(queue.size()>0){
   Node<T> out = queue.poll();
   list.add(out);
   if(out.getLeft()!=null){
    queue.offer(out.getLeft());
   }
   if(out.getRight()!=null){
    queue.offer(out.getRight());
   }
  }
  return list;
 }
 public static void main(String[] args) { 
  // TODO Auto-generated method stub 
  List<Node<String>> list = new ArrayList<Node<String>>(); 
  list.add(new Node<String>("a",7)); 
  list.add(new Node<String>("b",5)); 
  list.add(new Node<String>("c",4)); 
  list.add(new Node<String>("d",2)); 
   
  Node<String> root =huffuman.create(list); 
  System.out.println(huffuman.breadth(root)); 
//  System.out.println(list); 
 }
  
  
}

以上就是本文的全部內(nèi)容,希望對大家的學習有所幫助,也希望大家多多支持腳本之家。

相關(guān)文章

  • java網(wǎng)上商城開發(fā)之郵件發(fā)送功能(全)

    java網(wǎng)上商城開發(fā)之郵件發(fā)送功能(全)

    這篇文章主要介紹了java網(wǎng)上商城開發(fā)之郵件發(fā)送功能,第一部分介紹了環(huán)境配置,第二部分則介紹了具體實現(xiàn)代碼,感興趣的小伙伴們可以參考一下
    2016-03-03
  • Java日期時間以及日期相互轉(zhuǎn)換

    Java日期時間以及日期相互轉(zhuǎn)換

    這篇文章主要為大家詳細介紹了Java日期時間,以及日期相互轉(zhuǎn)換的方法,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2017-10-10
  • idea 自動生成類注釋和方法注釋的實現(xiàn)步驟

    idea 自動生成類注釋和方法注釋的實現(xiàn)步驟

    這篇文章主要介紹了idea 自動生成類注釋和方法注釋的實現(xiàn)步驟,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2019-12-12
  • Spring實戰(zhàn)之使用XML方式管理聲明式事務(wù)操作示例

    Spring實戰(zhàn)之使用XML方式管理聲明式事務(wù)操作示例

    這篇文章主要介紹了Spring實戰(zhàn)之使用XML方式管理聲明式事務(wù)操作,結(jié)合實例形式詳細分析了Spring XML方式管理聲明式事務(wù)具體步驟、配置、接口及使用技巧,需要的朋友可以參考下
    2020-01-01
  • Java多例設(shè)計模式實例詳解

    Java多例設(shè)計模式實例詳解

    這篇文章主要介紹了Java多例設(shè)計模式,結(jié)合實例形式分析了基于Java的多例模式概念、原理、定義與使用方法,需要的朋友可以參考下
    2018-05-05
  • java實現(xiàn)五子棋小游戲

    java實現(xiàn)五子棋小游戲

    這篇文章主要介紹了java實現(xiàn)五子棋小游戲的相關(guān)資料,十分簡單實用,推薦給大家,需要的朋友可以參考下
    2015-03-03
  • Java中的幾種關(guān)鍵字的使用小結(jié)

    Java中的幾種關(guān)鍵字的使用小結(jié)

    本文主要介紹了Java中的幾種關(guān)鍵字的使用小結(jié),文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2023-06-06
  • java實現(xiàn)單鏈表中的增刪改

    java實現(xiàn)單鏈表中的增刪改

    這篇文章主要為大家詳細介紹了java實現(xiàn)單鏈表中的增刪改,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2022-05-05
  • 5分鐘搞定java單例模式

    5分鐘搞定java單例模式

    單例模式(Singleton?Pattern)是?Java?中最簡單的設(shè)計模式之一。這種類型的設(shè)計模式屬于創(chuàng)建型模式,它提供了一種創(chuàng)建對象的最佳方式,本文給大家介紹下java單例模式的相關(guān)知識,感興趣的朋友一起看看吧
    2022-03-03
  • 使用Java實現(xiàn)MySQL數(shù)據(jù)鎖定的策略

    使用Java實現(xiàn)MySQL數(shù)據(jù)鎖定的策略

    在并發(fā)環(huán)境下,多個線程同時對MySQL數(shù)據(jù)庫進行讀寫操作可能會導致數(shù)據(jù)沖突和不一致的問題,為了解決這些并發(fā)沖突,我們可以采用數(shù)據(jù)鎖定策略來保證數(shù)據(jù)的一致性和完整性,下面將介紹如何使用Java實現(xiàn)MySQL數(shù)據(jù)鎖定策略,,需要的朋友可以參考下
    2023-08-08

最新評論