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

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>
            亚洲一区在线视频| 在线成人av网站| 国产日韩欧美视频在线| 亚洲丝袜av一区| 亚洲精品中文字幕有码专区| 久久人体大胆视频| 亚洲国产综合在线看不卡| 久久国产精品99久久久久久老狼| 国产久一道中文一区| 欧美在线观看一二区| 午夜精品福利视频| 亚洲在线一区二区三区| 国产精品每日更新| 美女性感视频久久久| 可以看av的网站久久看| 99爱精品视频| 久久乐国产精品| 一区二区三区高清在线观看| 日韩午夜av| 黄色在线一区| 中文网丁香综合网| 亚洲大片精品永久免费| 亚洲午夜性刺激影院| 亚洲国产欧美日韩精品| 亚洲欧美视频一区| 亚洲一区日韩在线| 欧美精品 日韩| 久久中文字幕导航| 国产精品日韩精品| 一本一本久久| 亚洲午夜视频在线观看| 男女视频一区二区| 欧美xxx成人| 狠狠色香婷婷久久亚洲精品| 亚洲特级毛片| 午夜视频久久久久久| 欧美日一区二区在线观看| 亚洲国产欧美日韩精品| 国产精品亚洲一区二区三区在线| 最新成人在线| 亚洲视频欧美在线| 国产精品视频网址| 欧美一区二区三区免费视频| 欧美一级成年大片在线观看| 国产精品久久网站| 久久成人在线| 亚洲大片在线| 免费不卡在线观看av| 久久先锋资源| 最新国产の精品合集bt伙计| 免费成人美女女| 在线视频日韩| 久久久久久久一区二区三区| 亚洲电影免费| 国产精品婷婷午夜在线观看| 欧美一区二区私人影院日本| 蜜桃伊人久久| 香蕉精品999视频一区二区| 国产亚洲激情在线| 欧美极品在线播放| 欧美一区二区三区在线视频| 欧美1区2区| 欧美一区二区三区视频在线| 亚洲国产精品成人| 国产人久久人人人人爽| 欧美午夜免费影院| 蜜臀av性久久久久蜜臀aⅴ四虎 | 日韩亚洲欧美成人一区| 国产精品国产三级国产专区53| 久久精品国产欧美亚洲人人爽| 日韩网站在线看片你懂的| 欧美电影免费观看网站| 久久久久久久久伊人| 午夜国产一区| 欧美亚洲网站| 亚洲综合色网站| 亚洲自拍三区| 亚洲男人的天堂在线aⅴ视频| 在线观看视频一区二区欧美日韩| 国产精品无码专区在线观看| 欧美日韩国产探花| 国产精品高精视频免费| 欧美连裤袜在线视频| 欧美大片专区| 欧美日韩免费一区二区三区| 欧美另类在线观看| 欧美成人综合一区| 亚洲国产黄色片| 日韩视频在线观看免费| 一区二区三区国产在线| 在线视频日本亚洲性| 亚洲欧美另类在线| 老司机免费视频一区二区| 美女免费视频一区| 国产精品国产a级| 激情另类综合| 亚洲一区二区在线看| 久久精品国产99国产精品澳门| 麻豆精品视频在线| 一区二区三区精品在线| 久久成人国产| 欧美婷婷久久| 亚洲高清在线精品| 亚洲欧美日韩一区在线观看| 免费毛片一区二区三区久久久| 亚洲精品资源| 久久久久综合网| 国产精品日本精品| 在线一区亚洲| 亚洲精品乱码久久久久久蜜桃91| 亚洲欧美日韩精品久久| 欧美日韩在线播放一区| 亚洲高清久久| 久久综合伊人77777尤物| 亚洲一区二区成人| 欧美日韩情趣电影| 最近中文字幕mv在线一区二区三区四区| 亚洲欧美日韩另类精品一区二区三区| 免费国产一区二区| 另类天堂视频在线观看| 国产字幕视频一区二区| 欧美中文字幕不卡| 亚洲免费小视频| 国产区亚洲区欧美区| 久久综合久色欧美综合狠狠| 性8sex亚洲区入口| 伊人精品成人久久综合软件| 鲁大师影院一区二区三区| 久久国产精品久久w女人spa| 午夜电影亚洲| 韩日精品视频| 亚洲高清自拍| 国产精品久久久一区二区三区| 亚洲一区二区三区激情| 亚洲免费视频观看| 在线播放日韩| 亚洲人成小说网站色在线| 欧美天堂亚洲电影院在线播放| 欧美一级淫片播放口| 开心色5月久久精品| 亚洲午夜一区二区| 久久天天躁狠狠躁夜夜av| 亚洲国产精品第一区二区| 9人人澡人人爽人人精品| 一区二区在线观看av| 最近中文字幕日韩精品| 国产一区二区日韩| 日韩一级裸体免费视频| 国内免费精品永久在线视频| 亚洲国产小视频| 激情综合自拍| 久久精品水蜜桃av综合天堂| 亚洲一级黄色片| 欧美成人国产va精品日本一级| 久久精品99国产精品酒店日本| 欧美三级电影精品| 亚洲国产精品一区二区www| 国产一区二区三区免费不卡 | 在线视频日韩| 免费观看在线综合色| 久久久久久网| 国产一区91精品张津瑜| 亚洲欧美日韩中文播放| 一区二区三区国产精华| 欧美精品日韩精品| 日韩亚洲一区二区| 先锋影音国产精品| 国产美女精品| 欧美一级二区| 亚洲成人直播| 美女黄毛**国产精品啪啪| 国产精品久久久久久模特| 一区二区欧美精品| 欧美伦理一区二区| 欧美激情影音先锋| 亚洲激情影院| 国产精品成人播放| 午夜日韩在线| 欧美成人免费网| 国产精品99久久不卡二区| 国产精品久久午夜| 久热精品视频在线观看一区| 亚洲黄色av| 久久香蕉精品| 亚洲网友自拍| 亚洲国产精品毛片| 国产精品高精视频免费| 理论片一区二区在线| 亚洲欧美成人一区二区在线电影| 久久一综合视频| 亚洲欧美日韩一区| 亚洲精品乱码久久久久久按摩观| 欧美日韩中字| 欧美激情亚洲综合一区| 久久精品色图| 午夜精品一区二区三区在线视| 欧美激情无毛| 久久综合激情| 欧美www视频| 欧美99久久|