青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品

pku1261 Huffman Trees 搜索與數(shù)據(jù)結(jié)構(gòu)結(jié)合的好題

題意:
一棵K叉哈弗曼樹,只有中間節(jié)點(diǎn)(滿兒子)和葉節(jié)點(diǎn)兩種。給出1-k的連續(xù)編碼,求出哈弗曼樹的結(jié)構(gòu)。

解法:
首先要清楚,哈弗曼編碼是一種沒有公共前綴的編碼,這提供了很重要的剪枝條件
另外,由于樹中只含有滿節(jié)點(diǎn)和空節(jié)點(diǎn)(葉子節(jié)點(diǎn)),故每分出一個(gè)枝條(從葉節(jié)點(diǎn)變?yōu)橐豢米訕洌┲辽僭黾觧-1個(gè)葉子節(jié)點(diǎn)。
利用以上兩點(diǎn),就可以很好的剪枝了。

剪枝判斷還是通過字典樹(額,這題中似乎叫哈弗曼樹比較合適- -)。詳細(xì)看程序吧。

代碼:
 1    # include <cstdio>
 2    # include <cstring>
 3    # include <vector>
 4    using namespace std;
 5    struct node
 6    {
 7        node *nxt[20];
 8        int count;
 9        bool end;
10        node()
11        {
12            memset(nxt,NULL,sizeof(nxt));
13            count=0;
14            end=0;
15        }

16    }
;
17    int z,n,count,len,c;
18    node buffer[100000];
19    node *head;
20    char str[250];
21    int ans[21];
22    void clear(node *p)
23    {
24        memset(p->nxt,NULL,sizeof(p->nxt));
25        p->end=false;
26        p->count=0;
27    }

28    bool solve(int s,int left,node *p)
29    {
30        if(count>z||p->end) return false;
31        if(s==len&&left==0return true;
32        else if(left<=0return false;
33        p->count++;
34        if(p->count==1)
35        {
36            p->end=true;
37            if(solve(s,left-1,head)) 
38                {
39                    ans[z-left+1]=s;
40                    return true;
41                }

42            p->end=false;
43        }

44        if(s==len)
45        {
46            p->count--;
47            return false;
48        }

49        if(p->count==1) count+=n-1;
50        if(p->nxt[str[s]-48]==NULL)
51        {
52            p->nxt[str[s]-48]=&buffer[c++];
53            clear(p->nxt[str[s]-48]);
54        }

55        if(solve(s+1,left,p->nxt[str[s]-48])) return true;
56        if(p->count==1) count-=n-1;
57        p->count--;
58        return false;    
59    }

60    int main()
61    {
62        int test;
63        scanf("%d",&test);
64        while(test--)
65        {
66            c=1;
67            count=1;
68            head=&buffer[0];
69            clear(head);
70            scanf("%d%d%s",&z,&n,str);
71            len=strlen(str);
72            solve(0,z,head);
73            ans[0]=0;
74            for(int i=0;i<z;i++)
75            {
76                printf("%d->",i);
77                for(int j=ans[i];j<ans[i+1];j++)
78                    printf("%c",str[j]);
79                printf("\n");
80            }

81        }

82        return 0;
83    }

posted on 2011-01-11 23:08 yzhw 閱讀(339) 評(píng)論(1)  編輯 收藏 引用 所屬分類: searchdata struct

評(píng)論

# re: pku1261 Huffman Trees 搜索與數(shù)據(jù)結(jié)構(gòu)結(jié)合的好題 2011-01-11 23:26 yzhw

有一點(diǎn)更正下,不是沒有公共前綴,而是字符的編碼不存在某個(gè)編碼是另一個(gè)編碼的前綴~  回復(fù)  更多評(píng)論   

<2011年3月>
272812345
6789101112
13141516171819
20212223242526
272829303112
3456789

導(dǎo)航

統(tǒng)計(jì)

公告

統(tǒng)計(jì)系統(tǒng)

留言簿(1)

隨筆分類(227)

文章分類(2)

OJ

最新隨筆

搜索

積分與排名

最新評(píng)論

閱讀排行榜

青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>
            亚洲女女做受ⅹxx高潮| 久久精品首页| 午夜精品一区二区三区电影天堂| 久久精品国亚洲| 亚洲精品精选| 久久久久国产一区二区三区| 国产精品久久久久久久久借妻| 亚洲高清在线播放| 久久这里只有精品视频首页| 亚洲男人的天堂在线aⅴ视频| 欧美精品一区二区三区久久久竹菊| 激情综合网址| 久久精品国产精品| 午夜精品999| 国产精品视频一二三| 这里只有精品视频| 韩国v欧美v日本v亚洲v| 国产精品一区亚洲| 99精品国产在热久久| 亚洲国产日韩精品| 欧美精品18+| 亚洲美女淫视频| 最新国产の精品合集bt伙计| 蜜乳av另类精品一区二区| 在线日韩中文字幕| 免费成人av在线| 久久在线91| 亚洲欧洲另类| 亚洲精品在线电影| 国产精品国产三级国产| 欧美在线欧美在线| 亚洲综合国产激情另类一区| 国产欧美一区二区三区久久| 鲁大师影院一区二区三区| 麻豆免费精品视频| 一区二区三区日韩欧美精品| 亚洲欧美另类中文字幕| 伊人狠狠色j香婷婷综合| 欧美高清在线一区| 欧美视频网站| 久久久美女艺术照精彩视频福利播放| 久久久久五月天| 一区二区三区产品免费精品久久75 | 国色天香一区二区| 亚洲电影中文字幕| 国产精品久久久久国产a级| 久久国产精品久久久| 久久综合狠狠综合久久综合88| 99riav1国产精品视频| 亚洲专区在线视频| 亚洲黄色成人久久久| 正在播放亚洲| 在线日韩av片| 亚洲一区二区精品在线观看| 激情欧美日韩一区| 亚洲午夜精品一区二区| 最近看过的日韩成人| 亚洲综合色在线| 亚洲欧洲视频在线| 久久精品五月| 香蕉成人啪国产精品视频综合网| 美女黄网久久| 欧美一区激情| 欧美日韩一区二区三区| 久热国产精品视频| 国产精品日韩一区| 亚洲国产成人在线播放| 国产香蕉97碰碰久久人人| 亚洲精品欧美一区二区三区| 国产一区在线播放| 亚洲欧美日韩在线| 一区二区三区精密机械公司| 久久精品日韩一区二区三区| 亚洲免费影视第一页| 欧美精品日韩综合在线| 免费亚洲一区二区| 国产一区二区三区久久悠悠色av| 亚洲一区二区三区在线| 欧美日韩国产成人在线| 亚洲人永久免费| 久久九九精品99国产精品| 中文日韩在线视频| 女生裸体视频一区二区三区| 久久国产免费| 国产精品一区二区黑丝| 日韩午夜三级在线| 亚洲精品在线观| 久久久久久香蕉网| 久久影视精品| 国产亚洲第一区| 午夜精品免费| 久久福利资源站| 国产日产精品一区二区三区四区的观看方式 | 亚洲国产一区在线观看| 亚洲丶国产丶欧美一区二区三区 | 欧美日韩在线精品| 亚洲精品免费在线观看| 日韩亚洲综合在线| 欧美高清一区二区| 亚洲国产精品一区二区www在线| 亚洲电影免费观看高清完整版在线观看 | 久久久久www| 美女露胸一区二区三区| 在线看日韩欧美| 猛男gaygay欧美视频| 亚洲欧洲综合| 亚洲一区日韩| 国产日韩精品久久久| 久久国产精品一区二区| 麻豆精品传媒视频| 亚洲精品午夜精品| 欧美日韩一区二区三区视频| 99精品久久久| 欧美一区影院| 在线观看精品一区| 欧美日本在线| 亚洲欧美电影在线观看| 宅男噜噜噜66国产日韩在线观看| 欧美区日韩区| 午夜激情久久久| 美女黄网久久| 一个色综合导航| 国产女主播一区二区| 久久精品最新地址| 亚洲精品中文字幕女同| 久久超碰97人人做人人爱| 揄拍成人国产精品视频| 欧美激情一区二区三区| 亚洲一区二区四区| 欧美激情bt| 久久gogo国模裸体人体| 亚洲国产精品美女| 国产精品高精视频免费| 久久久精品性| 亚洲亚洲精品在线观看| 在线播放国产一区中文字幕剧情欧美| 亚洲国产一区视频| 亚洲影院色无极综合| 亚洲一区二区三区色| 亚洲精品专区| 久久久亚洲精品一区二区三区| 亚洲欧美日韩在线| 久久久精品免费视频| 久久精品国产亚洲精品| 欧美va亚洲va香蕉在线| 91久久国产精品91久久性色| 亚洲一区二区精品在线| 国产精品极品美女粉嫩高清在线 | 伊人激情综合| 亚洲伦伦在线| 亚洲一二三区精品| 久久久综合网| 激情国产一区| 久久久www成人免费毛片麻豆| 中文在线资源观看视频网站免费不卡| 国产精品一区二区a| 亚洲欧洲一区二区三区| 免费久久精品视频| 久久久久久日产精品| 精品电影在线观看| 亚洲国产精品一区二区www| 欧美人与禽猛交乱配| 极品中文字幕一区| 久久视频这里只有精品| 日韩视频在线观看| 国产精品红桃| 久久久精彩视频| 久久国产精品久久久久久电车| 欧美日韩久久久久久| 午夜国产欧美理论在线播放| 亚洲欧美国产制服动漫| 激情国产一区| 久久综合久久综合久久综合| 在线观看日韩av先锋影音电影院| 一区二区三区视频观看| 亚洲一区二区三区中文字幕| 国产真实久久| 亚洲图片欧美日产| 欧美日韩国内| 久久伊人免费视频| 欧美永久精品| 在线中文字幕一区| 欧美成人国产| 亚洲国产高清自拍| 国产一区二区在线观看免费| 久久久久女教师免费一区| 免费永久网站黄欧美| 亚洲一区二区三| 欧美日韩亚洲另类| 亚洲欧洲一区二区三区久久| 亚洲人成绝费网站色www| 蜜臀av一级做a爰片久久| 国产精品福利在线观看| 久久丁香综合五月国产三级网站| 国产精品久久九九| 午夜精品av| 女生裸体视频一区二区三区| 午夜国产精品视频免费体验区| 午夜精品免费视频| 亚洲成人中文|