Rumah > Java > javaTutorial > Contoh analisis pokok Huffman di java

Contoh analisis pokok Huffman di java

王林
Lepaskan: 2023-04-28 23:16:23
ke hadapan
950 orang telah melayarinya

Pokok Huffman

1. Pengenalan asas

Contoh analisis pokok Huffman di java

2. Beberapa konsep dan contoh pokok Huffman

Contoh analisis pokok Huffman di java

Contoh analisis pokok Huffman di java

Langkah-langkah untuk membina pokok Huffman

Contoh analisis pokok Huffman di java

Contohnya: ambil arr = {1 3 6 7 8 13 29}

Contoh analisis pokok Huffman di java

public class HuffmanTree {
	public static void main(String[] args) {
		int[] arr = { 13, 7, 8, 3, 29, 6, 1 };
		Node root = createHuffmanTree(arr);
		preOrder(root);
	}
	// 编写一个前序遍历的方法
	public static void preOrder(Node root) {
		if (root != null) {
			root.preOrder();
		} else {
			System.out.println("树是空树,无法遍历~~");
		}
	}
	// 创建赫夫曼树的方法
	/**
	 * @param arr 需要创建成霍夫曼树的数组
	 * @return 创建好后的霍夫曼树的root节点
	 */
	public static Node createHuffmanTree(int[] arr) {
		// 第一步为了操作方便
		// 1.遍历 arr 数组
		// 2.将 arr 的每个元素构成一个Node
		// 3.将Node 放入到ArrayList中
		List<Node> nodes = new ArrayList<Node>();
		for (int value : arr) {
			nodes.add(new Node(value));
		}
		while (nodes.size() > 1) {
			// 排序从小到大
			Collections.sort(nodes);
			System.out.println("nodes = " + nodes); 
			// 取出根节点权值最小的两颗二叉树
			//注意:如果是从大到小排列的:就应该取倒数第一个和倒数第二个
			// (1) 取出权值最小的节点(二叉树)
			Node leftNode = nodes.get(0);
			// (2) 取出权值第二小的节点(二叉树)
			Node rightNode = nodes.get(1);
			// (3) 构建一颗新的二叉树
			Node parent = new Node(leftNode.value + rightNode.value);
			parent.left = leftNode;
			parent.right = rightNode;
			// (4) 从ArrayList删除处理过的二叉树
			nodes.remove(leftNode);
			nodes.remove(rightNode);
			// (5) 将parent加入到nodes
			nodes.add(parent);
		}
		// 返回赫夫曼树的root节点
		return nodes.get(0);
	}
}
//创建节点类
//为了让Node对象支持排序Collections集合排序
//让Node实现Comparable接口
class Node implements Comparable<Node> {
	int value;// 节点权值
	Node left;// 指向左子节点
	Node right;// 指向右子节点
 
	public Node(int value) {
		this.value = value;
	}
	// 写一个前序遍历
	public void preOrder() {
		System.out.println(this);
		if (this.left != null) {
			this.left.preOrder();
		}
		if (this.right != null) {
			this.right.preOrder();
		}
	}
	@Override
	public String toString() {
		return "Node [value=" + value + "]";
	}
	@Override
	public int compareTo(Node o) {
		// 表示从小到大排列
		return this.value - o.value;
	}
}
Salin selepas log masuk

Pengekodan Huffman

1. Pengenalan asas

Contoh analisis pokok Huffman di java

2. Analisis Prinsip

Contoh analisis pokok Huffman di java

Contoh analisis pokok Huffman di java

Contoh analisis pokok Huffman di java

Contoh analisis pokok Huffman di java

Contoh analisis pokok Huffman di java

6) Nota:

Panjang asal ialah 359, dimampatkan (359 - 133) / 359 = 62.9%

Pengekodan ini memenuhi pengekodan awalan, iaitu, tiada pengekodan aksara boleh Merupakan awalan untuk pengekodan aksara lain. Ia tidak akan menyebabkan kekaburan padanan;

Pengekodan Huffman ialah penyelesaian mampatan tanpa kerugian

Nota:

Contoh analisis pokok Huffman di java

Contoh analisis pokok Huffman di java

Contoh analisis pokok Huffman di java

Contoh analisis pokok Huffman di java

Nota tentang pengekodan Huffman fail termampat

1) Jika fail itu sendiri dimampatkan, Kemudian menggunakan pengekodan Huffman tidak akan mengubah dengan ketara kecekapan pemampatan, seperti video, ppt dan fail lain

2) Pengekodan Huffman diproses mengikut bait, jadi ia boleh memproses semua fail (Fail binari, fail teks)

3) Jika kandungan dalam fail tidak mempunyai banyak data berulang, kesan mampatan tidak akan jelas.

Atas ialah kandungan terperinci Contoh analisis pokok Huffman di java. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Label berkaitan:
sumber:yisu.com
Kenyataan Laman Web ini
Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn
Tutorial Popular
Lagi>
Muat turun terkini
Lagi>
kesan web
Kod sumber laman web
Bahan laman web
Templat hujung hadapan