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

pku1261 Huffman Trees 搜索與數據結構結合的好題

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

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

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

代碼:
 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) 評論(1)  編輯 收藏 引用 所屬分類: searchdata struct

評論

# re: pku1261 Huffman Trees 搜索與數據結構結合的好題 2011-01-11 23:26 yzhw

有一點更正下,不是沒有公共前綴,而是字符的編碼不存在某個編碼是另一個編碼的前綴~  回復  更多評論   

<2011年1月>
2627282930311
2345678
9101112131415
16171819202122
23242526272829
303112345

導航

統(tǒng)計

公告

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

留言簿(1)

隨筆分類(227)

文章分類(2)

OJ

最新隨筆

搜索

積分與排名

最新評論

閱讀排行榜

青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <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>
            精品成人国产| 欧美激情中文不卡| 亚洲福利在线观看| 久久爱www.| 久久国产88| 欧美一区二区视频免费观看| 亚洲欧美视频一区二区三区| 午夜精品久久久久久久99黑人| 一区二区三区免费在线观看| 在线视频亚洲| 久久精品国产亚洲a| 久久久蜜桃一区二区人| 美女视频一区免费观看| 最近中文字幕mv在线一区二区三区四区| 欧美激情精品久久久久久黑人 | 亚洲午夜羞羞片| 午夜电影亚洲| 蜜桃av一区二区| 亚洲人线精品午夜| 亚洲欧美精品一区| 欧美大胆人体视频| 国产精品视频一二| 亚洲国产第一| 亚洲欧美日韩精品久久久久| 久久久久久久久久久一区| 欧美国产日韩视频| 亚洲一区二区三区影院| 美国十次成人| 国产欧美一区二区精品仙草咪 | 国产精品久久久久免费a∨| 国产日韩欧美一区二区| 麻豆成人在线观看| 亚洲一区二区三| 久热re这里精品视频在线6| 亚洲麻豆一区| 久久久亚洲精品一区二区三区| 欧美日韩视频第一区| 黄色一区二区三区四区| 亚洲综合色网站| 亚洲欧洲日韩综合二区| 久久裸体艺术| 国产欧美婷婷中文| 亚洲一区二区影院| 亚洲国产高清在线| 久久精品首页| 国产精品伊人日日| 99精品视频免费全部在线| 免费欧美网站| 欧美一区二区三区四区在线| 欧美午夜片在线免费观看| 欧美国产一区二区在线观看| 国产女主播一区| 亚洲影院色在线观看免费| 亚洲电影免费观看高清完整版| 欧美一级久久久| 国产精品一区视频网站| 亚洲一区三区在线观看| 亚洲精选视频在线| 欧美极品在线播放| 亚洲美女av在线播放| 欧美国产欧美亚洲国产日韩mv天天看完整 | 国产精品成人一区二区三区夜夜夜| 亚洲国产高清在线观看视频| 老司机精品视频网站| 欧美一区在线看| 韩国v欧美v日本v亚洲v| 久久综合久久久久88| 久久久综合香蕉尹人综合网| 精品999在线观看| 裸体一区二区| 久久亚洲春色中文字幕| 91久久午夜| 野花国产精品入口| 国产精品一二三| 久久精品国产精品亚洲| 久久精品国产v日韩v亚洲 | 欧美一区二区播放| 鲁大师影院一区二区三区| 欧美与欧洲交xxxx免费观看| 国产欧美一区二区三区在线老狼| 亚洲伊人久久综合| 一区二区三区久久久| 欧美亚洲三区| 在线观看国产精品网站| 欧美成人免费在线| 欧美亚洲免费电影| 亚洲国产另类 国产精品国产免费| 久久久久久久久综合| 久久se精品一区二区| 伊人色综合久久天天| 欧美成人首页| 久久野战av| 欧美高清在线精品一区| 亚洲免费播放| 99精品热视频| 国产欧美日韩激情| 免费成人黄色| 欧美片第1页综合| 亚洲激情啪啪| 亚洲精品少妇30p| 国产精品jvid在线观看蜜臀| 欧美影院成年免费版| 久久爱91午夜羞羞| 亚洲二区视频| 久久亚洲精品一区二区| 午夜精品影院在线观看| 在线精品视频一区二区三四| 亚洲国产高清一区二区三区| 欧美视频日韩视频| 久久久久国产精品人| 免费在线观看一区二区| 亚洲尤物在线视频观看| 久久爱www.| 日韩一级片网址| 亚洲欧美亚洲| 亚洲国产欧美另类丝袜| 宅男精品视频| 宅男噜噜噜66国产日韩在线观看| 午夜视频在线观看一区二区三区| 在线免费观看成人网| 日韩一区二区免费看| 永久域名在线精品| 亚洲图片激情小说| 亚洲国产综合在线看不卡| 亚洲午夜av在线| 亚洲国产精品免费| 亚洲欧美成人| 国产精品99久久久久久久久久久久| 欧美一区二区三区视频| 一本久久综合| 老鸭窝91久久精品色噜噜导演| 久久久午夜电影| 国产精品久久久久久久午夜片| 欧美成人精品不卡视频在线观看 | 国产精品一区二区久久国产| 欧美成人性网| 国产欧美91| 亚洲免费观看视频| 亚洲三级毛片| 欧美亚洲一区二区三区| 亚洲一区二区欧美| 夜夜狂射影院欧美极品| 亚洲电影第1页| 亚洲精品久久久久久下一站 | 亚洲美女精品一区| 毛片一区二区| 欧美片在线观看| 欧美一区二区三区在线| 久久人人爽人人爽爽久久| 夜久久久久久| 欧美一区二区三区四区在线观看| 免费在线成人| 99热在这里有精品免费| 国产一区二区三区黄| 亚洲国产精品欧美一二99| 国产精品久久久亚洲一区| 蜜臀av性久久久久蜜臀aⅴ四虎 | 亚洲国产精品免费| 一级成人国产| 国产亚洲精品久久久久婷婷瑜伽| 亚洲综合精品| 国产在线观看一区| 日韩视频精品| 狠狠久久综合婷婷不卡| 日韩一级大片在线| 欧美成人xxx| 亚洲欧美日韩精品久久奇米色影视| 午夜宅男欧美| 中国成人黄色视屏| 久久久久久久波多野高潮日日 | 牛牛影视久久网| 欧美一区二区三区四区在线观看地址| 久久精品人人做人人爽电影蜜月| 亚洲视频网在线直播| 欧美激情精品久久久六区热门| 久久久国产精品亚洲一区 | 亚洲私人影吧| 国产日韩欧美视频在线| 欧美承认网站| 久久伊人精品天天| 欧美日韩成人网| 久久蜜桃精品| 国产女人精品视频| 国产网站欧美日韩免费精品在线观看 | 亚洲美女91| 99在线精品视频在线观看| 久久嫩草精品久久久久| 国产精品久久久久av免费| 亚洲国产成人午夜在线一区| 国产亚洲精品久| 欧美一区二区三区视频免费| 欧美在线播放视频| 国产精品一区视频| 美女网站在线免费欧美精品| 久久疯狂做爰流白浆xx| 国产日韩欧美在线| 亚洲午夜精品福利| 韩日精品中文字幕| 久久久久久久波多野高潮日日| 久久久www成人免费精品|