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

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

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

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

剪枝判斷還是通過(guò)字典樹(額,這題中似乎叫哈弗曼樹比較合適- -)。詳細(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 閱讀(352) 評(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)更正下,不是沒(méi)有公共前綴,而是字符的編碼不存在某個(gè)編碼是另一個(gè)編碼的前綴~  回復(fù)  更多評(píng)論   

<2025年12月>
30123456
78910111213
14151617181920
21222324252627
28293031123
45678910

導(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>
            欧美国产日韩xxxxx| 国产免费观看久久| 亚洲经典三级| 亚洲日韩欧美视频一区| 久久亚洲综合色| 欧美成人综合一区| 91久久视频| 久久综合久色欧美综合狠狠| 久久亚洲国产成人| 在线欧美福利| 免费久久久一本精品久久区| 亚洲第一精品在线| 一区二区三区毛片| 国产精品激情偷乱一区二区∴| 亚洲一二三级电影| 久久av一区| 一区二区在线看| 欧美国产欧美亚洲国产日韩mv天天看完整 | 欧美人成在线视频| 日韩视频第一页| 亚洲午夜精品17c| 国产精品亚洲综合一区在线观看 | 亚洲永久免费视频| 久久精品国产一区二区电影| 极品尤物一区二区三区| 欧美风情在线观看| 亚洲婷婷国产精品电影人久久 | 久久免费精品视频| 亚洲国产一区二区三区在线播 | 亚洲欧洲一二三| 国产精品亚洲综合| 欧美国产日韩在线观看| 先锋影院在线亚洲| 妖精视频成人观看www| 另类欧美日韩国产在线| 亚洲欧美影院| 在线视频欧美一区| 91久久夜色精品国产九色| 国产日韩精品一区二区三区| 欧美极品一区| 久久午夜精品一区二区| 亚洲欧美激情四射在线日 | 性亚洲最疯狂xxxx高清| 日韩亚洲在线| 欧美激情第10页| 久久免费观看视频| 欧美一级午夜免费电影| 一本色道久久综合狠狠躁篇怎么玩| 国产在线拍揄自揄视频不卡99| 欧美日韩一卡| 欧美精品在线一区二区三区| 久久一区二区视频| 久久精品亚洲精品| 欧美综合第一页| 香蕉国产精品偷在线观看不卡 | 欧美一区二区福利在线| 国产精品99久久久久久www| 91久久国产自产拍夜夜嗨| 美女性感视频久久久| 久久成人免费网| 久久成人国产精品| 欧美一区二区日韩一区二区| 亚洲欧洲99久久| 亚洲欧美欧美一区二区三区| 亚洲一区二区久久| 亚洲性线免费观看视频成熟| 一区二区三区 在线观看视频| 亚洲免费激情| 一区二区日韩| 亚洲尤物视频网| 亚洲免费在线看| 亚洲一区国产| 亚洲欧美美女| 久久riav二区三区| 久久久噜噜噜久噜久久| 久久精品夜色噜噜亚洲aⅴ| 久久精品女人的天堂av| 久久九九免费| 久久人人97超碰精品888| 久久久亚洲国产美女国产盗摄| 久久久国产精彩视频美女艺术照福利| 欧美综合二区| 麻豆九一精品爱看视频在线观看免费| 久久中文字幕导航| 亚洲国产精品999| 亚洲伦理网站| 午夜精品在线观看| 老司机aⅴ在线精品导航| 欧美黄网免费在线观看| 欧美日产一区二区三区在线观看 | 激情亚洲网站| 亚洲精品你懂的| 亚洲一区在线视频| 久久久之久亚州精品露出| 免费观看在线综合| 亚洲精品视频在线播放| 亚洲一区二区成人在线观看| 欧美一区二区三区视频在线| 久久久久久一区二区| 欧美精品乱码久久久久久按摩| 国产精品久久999| 国产一区二区三区久久| 91久久夜色精品国产网站| 亚洲一区欧美二区| 久热精品视频在线免费观看| 欧美激情导航| 亚洲一区二区网站| 久久综合伊人| 欧美亚韩一区| 一区二区在线视频播放| 亚洲视频在线观看三级| 久久另类ts人妖一区二区| 亚洲老司机av| 久久精品国产99国产精品澳门| 欧美精品久久天天躁| 国产一区二区久久久| 99视频+国产日韩欧美| 久久久噜噜噜久久狠狠50岁| 日韩亚洲成人av在线| 久久久国产一区二区| 欧美丝袜第一区| 亚洲国产精品一区| 欧美在线亚洲综合一区| 欧美国产精品一区| 亚洲欧美文学| 欧美日韩伦理在线免费| 亚洲国产精品久久久久秋霞蜜臀| 亚洲一二三四久久| 亚洲国产精品成人一区二区| 香蕉久久精品日日躁夜夜躁| 欧美日韩一区二区三区在线看| 精品粉嫩aⅴ一区二区三区四区| 亚洲欧美激情视频| 亚洲激情第一页| 久久另类ts人妖一区二区| 国产精品一区免费在线观看| 一本到12不卡视频在线dvd| 欧美成人精品一区二区三区| 亚洲欧美日韩在线综合| 欧美视频一区二区三区在线观看| 亚洲国产精品第一区二区三区 | 亚洲午夜精品一区二区| 欧美激情在线有限公司| 亚洲第一页在线| 久久亚洲精品一区| 午夜亚洲福利| 国产精品日韩二区| 亚洲一区久久久| 日韩视频一区| 欧美日韩一区二区在线观看视频 | 一本久道综合久久精品| 欧美国产精品人人做人人爱| 久久午夜av| 在线观看一区| 免费一级欧美片在线播放| 久久国产成人| 激情一区二区三区| 蜜桃av综合| 老牛嫩草一区二区三区日本| 亚洲二区免费| 亚洲国产精品成人久久综合一区| 久久综合久久88| 亚洲国产影院| 亚洲全部视频| 欧美深夜影院| 午夜电影亚洲| 欧美一区二区日韩一区二区| 国产一区二区三区的电影 | 国产毛片一区| 久久福利毛片| 欧美怡红院视频| 国外成人在线| 男女精品网站| 欧美极品在线播放| 亚洲视频香蕉人妖| 亚洲一区二区三区在线视频 | 在线观看欧美精品| 亚洲大胆在线| 欧美天天综合网| 欧美影院成年免费版| 久久精品国产亚洲精品| 在线精品在线| 亚洲欧洲精品一区二区三区不卡 | 久久久久成人网| 久久这里只有| 99精品国产福利在线观看免费| 一本一本久久a久久精品综合麻豆| 国产精品福利片| 久久久综合香蕉尹人综合网| 欧美大片免费观看在线观看网站推荐| 中文日韩在线| 欧美一区视频| 亚洲精品在线观看视频| 亚洲无线一线二线三线区别av| 国产一区二区三区日韩欧美| 欧美国产日本高清在线| 欧美午夜a级限制福利片| 久久天天狠狠| 欧美日韩一卡二卡| 老司机一区二区|