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

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>
            亚洲人成啪啪网站| 亚洲免费电影在线| 日韩网站在线观看| 在线亚洲自拍| 亚洲欧美怡红院| 亚洲网站在线看| 一本大道久久精品懂色aⅴ| 欧美亚洲在线视频| 国产精品视频第一区| 亚洲一区二区三区在线播放| 久久精品国产2020观看福利| 国产亚洲高清视频| 久久狠狠亚洲综合| 久久久久久网址| 亚洲国产精品久久久久婷婷884 | 欧美黄色精品| 99这里有精品| 黑人巨大精品欧美黑白配亚洲 | 欧美日韩成人在线观看| 欧美一级淫片aaaaaaa视频| 欧美极品aⅴ影院| 亚洲精品视频中文字幕| 亚洲校园激情| 亚洲电影免费观看高清完整版在线观看 | 亚洲激情视频在线播放| 亚洲欧美另类国产| 国产精品福利网| 在线一区二区三区四区五区| 久久在线免费| 久久久夜色精品亚洲| 亚洲伊人久久综合| 亚洲综合视频一区| 久久福利影视| 一区二区三区在线视频观看| 国产精品九九| 国产精品久久久久久久久免费| 欧美成人按摩| 欧美人交a欧美精品| 欧美激情综合亚洲一二区| 久久在线免费| 久久久久88色偷偷免费| 亚洲国产精品电影| 麻豆成人精品| 欧美激情一区二区三区在线| 欧美亚男人的天堂| 蜜臀av性久久久久蜜臀aⅴ四虎| 亚洲主播在线| 亚洲欧美在线另类| 久久嫩草精品久久久精品| 亚洲欧美视频在线| 亚洲在线观看免费| 久久人人爽国产| 亚洲国产精品久久久久婷婷老年| 最新国产成人av网站网址麻豆| 美女久久一区| 正在播放日韩| 午夜在线不卡| 欧美华人在线视频| 国产视频亚洲精品| 国产精品一区二区久久国产| 欧美视频手机在线| 久久婷婷综合激情| 亚洲一区二区三区四区在线观看| 尹人成人综合网| 亚洲欧洲综合另类| 毛片基地黄久久久久久天堂| 亚洲性视频网站| 亚洲丁香婷深爱综合| 久久午夜精品| 亚洲国产精品成人va在线观看| 久久阴道视频| 麻豆精品视频在线观看| 国产精品久久999| 午夜精品美女自拍福到在线| 亚洲伊人色欲综合网| 国产综合第一页| 男人天堂欧美日韩| 免费在线观看日韩欧美| 怡红院精品视频| 久久午夜电影| 欧美日韩精品免费看| 欧美性猛交xxxx乱大交退制版| 国产精品一区久久久久| 一二美女精品欧洲| 免费视频一区| 欧美在线免费观看| 一本色道久久综合亚洲二区三区 | 男女激情久久| 国产伦精品一区二区三区视频孕妇 | 久久青草欧美一区二区三区| 亚洲黄色成人| 欧美精品一二三| 1000部精品久久久久久久久| 久久综合综合久久综合| 美女网站久久| 亚洲巨乳在线| 日韩视频一区二区三区在线播放免费观看 | 久久精品成人欧美大片古装| 欧美日韩在线视频一区| 久久久久.com| 国产精自产拍久久久久久蜜| 亚洲片在线资源| 亚洲国产精品va在看黑人| 亚洲尤物在线视频观看| 欧美日韩 国产精品| 午夜精品福利一区二区三区av | 欧美日韩一卡| 久久精品国产清高在天天线| 你懂的一区二区| 久久国产精品毛片| 欧美连裤袜在线视频| 欧美成人精品一区| 国产人成精品一区二区三| 亚洲国产精品一区二区第一页 | 欧美福利电影网| 久久国产精品一区二区三区| 国产一区二区三区在线观看免费| 亚洲欧美日韩久久精品| 欧美日韩成人一区二区三区| 一区二区三区高清在线| 久久精品一二三| 99国产精品视频免费观看| 欧美视频专区一二在线观看| 亚洲综合视频1区| 欧美 日韩 国产一区二区在线视频| 亚洲国产精品一区在线观看不卡| 欧美精品激情| 午夜日韩视频| 免费人成网站在线观看欧美高清| 一区二区三区四区五区视频| 韩国欧美一区| 久久久久.com| 日韩一级在线观看| 国产亚洲精品久久久| 欧美jjzz| 欧美一区二区免费观在线| 夜夜嗨av一区二区三区| 日韩亚洲欧美综合| 国产欧美日韩精品一区| 欧美一级久久| 欧美激情va永久在线播放| 亚洲一区二区黄| 国产色产综合产在线视频| 欧美护士18xxxxhd| 亚洲一区二区在线免费观看视频| 亚洲国语精品自产拍在线观看| 亚洲综合视频一区| 亚洲国产cao| 国产日韩欧美综合精品| 欧美久久久久久蜜桃| 欧美在线亚洲一区| 亚洲欧美久久久| 亚洲大胆av| 久久成人人人人精品欧| 欧美精品久久99久久在免费线| 久久精品盗摄| 久久综合伊人| 欧美成人精品在线| 欧美大学生性色视频| 久久婷婷蜜乳一本欲蜜臀| 亚洲一区二区少妇| 亚洲韩国日本中文字幕| 久久久亚洲精品一区二区三区| 亚洲免费在线播放| 麻豆成人在线| 日韩小视频在线观看| 久久久夜夜夜| 久久精品水蜜桃av综合天堂| 日韩一区二区福利| 在线看日韩欧美| 久久久亚洲精品一区二区三区 | 欧美高清在线精品一区| 午夜精品视频网站| 中文久久精品| 这里只有视频精品| 一本色道久久综合亚洲精品婷婷 | 欧美激情亚洲精品| 久久午夜羞羞影院免费观看| 欧美制服丝袜| 久久精品日韩一区二区三区| 亚洲欧美中文日韩在线| 亚洲一区二区精品| 亚洲一区二区欧美| 99热免费精品| 亚洲免费婷婷| 久久久天天操| 久久只有精品| 欧美r片在线| 欧美日韩国产精品一卡| 欧美午夜久久| 国产亚洲福利| 亚洲精品久久久久久久久久久久久| 尤物九九久久国产精品的特点| 亚洲国产二区| 国产精品99久久久久久久女警| 午夜精品久久久久久| 麻豆av一区二区三区久久| 亚洲人成在线观看| 中文在线一区| 欧美mv日韩mv亚洲|