亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 編程 > Java > 正文

java實現哈弗曼編碼與反編碼實例分享(哈弗曼算法)

2019-11-26 15:48:05
字體:
來源:轉載
供稿:網友

復制代碼 代碼如下:

//哈弗曼編碼的實現類
public class HffmanCoding {
    private int charsAndWeight[][];// [][0]是 字符,[][1]存放的是字符的權值(次數)
    private int hfmcoding[][];// 存放哈弗曼樹
    private int i = 0;// 循環變量
    private String hcs[];
    public HffmanCoding(int[][] chars) {
        // TODO 構造方法
        charsAndWeight = new int[chars.length][2];
        charsAndWeight = chars;
        hfmcoding = new int[2 * chars.length - 1][4];// 為哈弗曼樹分配空間
    }
    // 哈弗曼樹的實現
    public void coding() {
        int n = charsAndWeight.length;
        if (n == 0)
            return;
        int m = 2 * n - 1;
        // 初始化哈弗曼樹
        for (i = 0; i < n; i++) {
            hfmcoding[i][0] = charsAndWeight[i][1];// 初始化哈弗曼樹的權值
            hfmcoding[i][1] = 0;// 初始化哈弗曼樹的根節點
            hfmcoding[i][2] = 0;// 初始化哈弗曼樹的左孩子
            hfmcoding[i][3] = 0;// 初始化哈弗曼樹的右孩子
        }
        for (i = n; i < m; i++) {
            hfmcoding[i][0] = 0;// 初始化哈弗曼樹的權值
            hfmcoding[i][1] = 0;// 初始化哈弗曼樹的根節點
            hfmcoding[i][2] = 0;// 初始化哈弗曼樹的左孩子
            hfmcoding[i][3] = 0;// 初始化哈弗曼樹的右孩子
        }
        // 構建哈弗曼樹
        for (i = n; i < m; i++) {
            int s1[] = select(i);// 在哈弗曼樹中查找雙親為零的 weight最小的節點
            hfmcoding[s1[0]][1] = i;// 為哈弗曼樹最小值付雙親
            hfmcoding[s1[1]][1] = i;
            hfmcoding[i][2] = s1[0];// 新節點的左孩子
            hfmcoding[i][3] = s1[1];// 新節點的右孩子
            hfmcoding[i][0] = hfmcoding[s1[0]][0] + hfmcoding[s1[1]][0];// 新節點的權值是左右孩子的權值之和
        }
    }
    // 查找雙親為零的 weight最小的節點
    private int[] select(int w) {
        // TODO Auto-generated method stub
        int s[] = { -1, -1 }, j = 0;// s1 最小權值且雙親為零的節點的序號 , i 是循環變量
        int min1 = 32767, min2 = 32767;
        for (j = 0; j < w; j++) {
            if (hfmcoding[j][1] == 0) {// 只在尚未構造二叉樹的結點中查找(雙親為零的節點)
                if (hfmcoding[j][0] < min1) {
                    min2 = min1;
                    s[1] = s[0];
                    min1 = hfmcoding[j][0];
                    s[0] = j;
                } else if (hfmcoding[j][0] < min2) {
                    min2 = hfmcoding[j][0];
                    s[1] = j;
                }
            }
        }
        return s;
    }
    public String[] CreateHCode() {// 根據哈夫曼樹求哈夫曼編碼
        int n = charsAndWeight.length;
        int i, f, c;
        String hcodeString = "";
        hcs = new String[n];
        for (i = 0; i < n; i++) {// 根據哈夫曼樹求哈夫曼編碼
            c = i;
            hcodeString = "";
            f = hfmcoding[i][1]; // f 哈弗曼樹的根節點
            while (f != 0) {// 循序直到樹根結點
                if (hfmcoding[f][2] == c) {// 處理左孩子結點
                    hcodeString += "0";
                } else {
                    hcodeString += "1";
                }
                c = f;
                f = hfmcoding[f][1];
            }
            hcs[i] = new String(new StringBuffer(hcodeString).reverse());
        }
        return hcs;
    }
    public String show(String s) {// 對字符串顯示編碼
        String textString = "";
        char c[];
        int k = -1;
        c = new char[s.length()];
        c = s.toCharArray();// 將字符串轉化為字符數組
        for (int i = 0; i < c.length; i++) {
            k = c[i];
            for (int j = 0; j < charsAndWeight.length; j++)
                if (k == charsAndWeight[j][0])
                    textString += hcs[j];
        }
        return textString;
    }
    // 哈弗曼編碼反編譯
    public String reCoding(String s) {
        String text = "";// 存放反編譯后的字符
        int k = 0, m = hfmcoding.length - 1;// 從根節點開始查詢
        char c[];
        c = new char[s.length()];
        c = s.toCharArray();
        k = m;
        for (int i = 0; i < c.length; i++) {
            if (c[i] == '0') {
                k = hfmcoding[k][2];// k的值為根節點左孩子的序號
                if (hfmcoding[k][2] == 0 && hfmcoding[k][3] == 0)// 判斷是不是葉子節點,條件(左右孩子都為零)
                {
                    text += (char) charsAndWeight[k][0];
                    k = m;
                }
            }
            if (c[i] == '1') {
                k = hfmcoding[k][3];// k的值為根節點右孩子的序號
                if (hfmcoding[k][2] == 0 && hfmcoding[k][3] == 0)// 判斷是不是葉子節點,條件(左右孩子都為零)
                {
                    text += (char) charsAndWeight[k][0];
                    k = m;
                }
            }
        }
        return text;
    }
}

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
国产亚洲欧美日韩一区二区| 亚洲色图偷窥自拍| 久久精品小视频| 成人激情av在线| 欧美亚洲视频在线看网址| 国产成人一区二区三区电影| 久久久国产视频| 国产精品视频白浆免费视频| 欧美电影免费观看网站| 欧美日本精品在线| 亚洲欧美日韩网| 日韩免费高清在线观看| 亚洲精品综合精品自拍| 日本高清视频精品| 亚洲第一偷拍网| 亚洲www在线观看| 亚洲人成电影在线| 国产欧美日韩免费| 欧美综合国产精品久久丁香| 日韩大片在线观看视频| 亚洲精品456在线播放狼人| 午夜精品在线观看| 色综合久久悠悠| 欧美激情一二三| 亚洲精品99久久久久| 91中文在线观看| 欧美高跟鞋交xxxxxhd| 国产精品福利在线观看| 亚洲国产成人爱av在线播放| 久久99热精品这里久久精品| 久久激情视频久久| 亚洲精品一区二区久| 精品国产欧美成人夜夜嗨| 98精品国产自产在线观看| 精品香蕉在线观看视频一| 91人人爽人人爽人人精88v| 成人午夜黄色影院| 伊人成人开心激情综合网| 国内精品美女av在线播放| 在线视频一区二区| 国产区亚洲区欧美区| 97精品在线视频| 人人爽久久涩噜噜噜网站| 亚洲va欧美va国产综合剧情| 中文字幕精品一区久久久久| 欧美精品在线第一页| 91精品国产91久久久久| 国产成人精品免费视频| 97超碰色婷婷| 成人黄色免费在线观看| 日韩欧美国产一区二区| 精品国产一区av| 国产精品视频导航| 亚洲r级在线观看| 日韩在线观看免费全| 成人h片在线播放免费网站| 欧美成人黑人xx视频免费观看| 精品视频9999| 国产极品jizzhd欧美| 中文字幕日韩欧美在线视频| 亚洲激情视频在线播放| 国产欧美精品va在线观看| 91精品久久久久久久久| 久久久久久久999| 国产欧美亚洲精品| 亚洲香蕉伊综合在人在线视看| 精品国产美女在线| 91精品中国老女人| 亚洲jizzjizz日本少妇| 精品亚洲精品福利线在观看| 国产精品久久久久久久久久99| 久久6精品影院| 亚洲毛片在线免费观看| 国产极品精品在线观看| 精品动漫一区二区三区| 97精品久久久中文字幕免费| 一本色道久久88亚洲综合88| 91久久久久久久久久| 久久激情五月丁香伊人| 日韩在线免费视频| 亚洲加勒比久久88色综合| 日本老师69xxx| 理论片在线不卡免费观看| 亚洲欧美日韩天堂一区二区| 亚洲精品99久久久久| 欧美成人性生活| www日韩中文字幕在线看| 黄色成人在线播放| 国产精品成人一区二区| 亚洲午夜精品久久久久久性色| 国产综合久久久久| 一个人www欧美| 中文字幕九色91在线| 久久久久久久国产精品| 久久亚洲精品小早川怜子66| 久久久精品中文字幕| 欧美激情免费在线| 欧美另类交人妖| 欧美日韩在线视频一区二区| 国产成人精品a视频一区www| 国产视频欧美视频| 91色琪琪电影亚洲精品久久| 亚洲欧美激情在线视频| 中文字幕九色91在线| 日韩成人av网址| 国产成人综合av| 久久97精品久久久久久久不卡| 亚洲男人7777| 欧美老少做受xxxx高潮| 最近2019好看的中文字幕免费| 懂色aⅴ精品一区二区三区蜜月| 日韩高清免费在线| 深夜福利日韩在线看| 欧美色图在线视频| 亚洲精品第一页| 欧美成人午夜激情视频| 精品中文字幕在线2019| 亚洲视频专区在线| 亚洲大胆美女视频| 国产精品久久久久不卡| 人人澡人人澡人人看欧美| 国产精品免费久久久| 欧美激情精品久久久久久黑人| 777国产偷窥盗摄精品视频| 日韩欧美中文免费| 国产成人精品综合久久久| 国产精品成人一区二区| 国产精品高清在线观看| 日韩精品高清在线| 中文字幕亚洲天堂| 亚洲第一二三四五区| 亚洲男人天堂网| 日韩在线视频播放| 欧美一区二区三区四区在线| 日韩精品高清视频| 日韩小视频在线观看| 日韩免费在线播放| 久久影院资源站| 亚洲xxxxx电影| 欧美大片欧美激情性色a∨久久| 日韩精品视频在线| 青青精品视频播放| 成人黄色激情网| 欧美日韩在线影院| 精品视频偷偷看在线观看| 久久成人av网站| 久热精品视频在线观看一区| 热久久免费视频精品| 欧美精品午夜视频| 亚洲一区av在线播放| 精品亚洲男同gayvideo网站| 久久国产精品久久久久久久久久| 欧美日韩在线看| 最近2019中文字幕mv免费看| 久久99精品久久久久久琪琪| 欧美麻豆久久久久久中文| 午夜精品久久久久久久久久久久| 日韩一区视频在线| 欧美成人自拍视频| 欧美尺度大的性做爰视频| 国产98色在线| 成人免费视频网| 亚洲永久免费观看| 欧美日韩中文字幕在线视频|