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

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

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

解法:
首先要清楚,哈弗曼編碼是一種沒有公共前綴的編碼,這提供了很重要的剪枝條件
另外,由于樹中只含有滿節點和空節點(葉子節點),故每分出一個枝條(從葉節點變為一棵子樹)至少增加n-1個葉子節點。
利用以上兩點,就可以很好的剪枝了。

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

代碼:
 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

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

<2025年10月>
2829301234
567891011
12131415161718
19202122232425
2627282930311
2345678

導航

統計

公告

統計系統

留言簿(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>
            亚洲激情视频| 在线免费日韩片| 美女91精品| 国产精品男女猛烈高潮激情| 亚洲在线电影| 亚洲自拍电影| 在线视频你懂得一区二区三区| 亚洲第一黄网| 久久精品麻豆| 香蕉久久夜色| 久久精品2019中文字幕| 亚洲欧美日韩成人| 亚洲欧美春色| 久久综合福利| 欧美大胆成人| 亚洲人成人一区二区在线观看| 久久综合一区| 1000部国产精品成人观看| 激情欧美日韩| 亚洲欧洲另类| 欧美亚洲日本一区| 久久午夜精品| 欧美xx69| 国产热re99久久6国产精品| 国产日韩亚洲欧美| 日韩视频在线免费观看| 午夜一级久久| 91久久久久久国产精品| 亚洲欧美日韩国产成人| 久久久久久一区二区三区| 欧美肥婆在线| 精品动漫av| 欧美在线3区| 日韩亚洲国产欧美| 榴莲视频成人在线观看| 国产乱码精品一区二区三区不卡| 亚洲人久久久| 欧美xx69| 欧美www视频| 日韩午夜电影| 亚洲伦理网站| 欧美日韩视频免费播放| 99精品久久| 日韩视频精品| 国产精品久久久久久久久免费樱桃| 国产一区二区三区成人欧美日韩在线观看 | 亚洲福利专区| 欧美黄色一级视频| 欧美成人精品1314www| 亚洲综合精品一区二区| 欧美日韩成人精品| 亚洲经典在线| 亚洲国产小视频| 老司机午夜精品视频| 国内精品久久久久影院优| 亚洲欧美美女| 亚洲一卡久久| 国产日韩av一区二区| 欧美久久一区| 久久国产精品黑丝| 久久精品国产99精品国产亚洲性色| 国产精品wwwwww| 亚洲一区观看| 欧美一区二区三区久久精品| 国产精品一区二区女厕厕| 久久国产一区| 久久人体大胆视频| 在线观看欧美日韩| 欧美淫片网站| 欧美裸体一区二区三区| 一本色道久久综合狠狠躁的推荐| 亚洲区国产区| 国产欧美欧美| 欧美大片免费观看在线观看网站推荐| 久久美女性网| 亚洲你懂的在线视频| 欧美69视频| 欧美专区日韩专区| 欧美在线短视频| 久久国产精品99国产精| 欧美国产日产韩国视频| 久久一区二区视频| 国产精品一区二区黑丝| 欧美成年人在线观看| 亚洲人成毛片在线播放| 国产精品久久久久秋霞鲁丝| 免费在线观看日韩欧美| 国产精品日韩电影| 亚洲国产成人久久| 99精品视频一区二区三区| 欧美一区二区三区日韩视频| 亚洲在线电影| 欧美日韩午夜在线视频| 亚洲国产黄色| 中文日韩电影网站| 欧美日韩精品在线视频| 亚洲精品午夜| 亚洲精品在线视频| 欧美午夜片在线观看| 亚洲视频中文字幕| 亚洲欧美视频在线| 黄色亚洲网站| 欧美成人激情视频| 欧美电影在线观看完整版| 亚洲福利视频在线| 国产精品高潮呻吟视频| 亚洲欧美在线另类| 美女国产精品| 中文有码久久| 精品成人久久| 国产精品美女www爽爽爽| 午夜精品福利视频| 欧美激情国产高清| 香蕉乱码成人久久天堂爱免费 | 亚洲精品久久久久久久久久久久| 久久一区亚洲| 亚洲欧美偷拍卡通变态| 欧美激情第五页| 亚洲人在线视频| 久久久国产亚洲精品| 亚洲美女在线观看| 宅男在线国产精品| 美女黄网久久| 久久精品99国产精品日本| 亚洲另类黄色| 国产精品日韩欧美大师| 国产精品制服诱惑| 国产精品九色蝌蚪自拍| 欧美精品三级| 欧美精品久久久久a| 牛牛影视久久网| 99视频一区二区| 亚洲网友自拍| 欧美一区二区成人6969| 亚洲免费中文| 久久综合999| 老牛影视一区二区三区| 亚洲一二三级电影| 久热精品视频| 欧美日韩国产精品一区| 欧美日韩亚洲激情| 国产精品一卡| 亚洲日本欧美天堂| 99re视频这里只有精品| 亚洲午夜精品久久| 亚洲精品一区二| 国产亚洲欧美中文| 亚洲美女电影在线| 亚洲欧美另类综合偷拍| 久久精品最新地址| 亚洲国产精品女人久久久| 欧美一区中文字幕| 欧美精品一区二| 亚洲欧美综合v| 欧美精品久久99| 狠狠综合久久av一区二区老牛| 亚洲精品乱码久久久久久黑人| 亚洲在线中文字幕| 欧美激情在线| 午夜精品福利在线观看| 欧美电影在线| 99精品国产在热久久下载| 国产亚洲精品久久久久久| 亚洲国产精品成人va在线观看| 一区二区av| 亚洲国产日韩欧美| 久久精品视频免费播放| 欧美日韩高清一区| 国产日韩欧美二区| 亚洲自拍都市欧美小说| 亚洲第一久久影院| 亚洲一区免费| 欧美日本一区二区三区| 亚洲美女毛片| 免费观看一区| 麻豆精品视频在线观看视频| 久久人人超碰| 欧美激情中文字幕乱码免费| 欧美中文在线字幕| 亚洲一本视频| 久久亚洲综合网| 老鸭窝亚洲一区二区三区| 夜夜爽www精品| 在线观看91久久久久久| 国产日韩精品一区二区三区| 欧美日韩亚洲另类| 国产精品亚洲综合| 欧美午夜精品久久久久久浪潮| 国产欧美日韩不卡| 韩日欧美一区二区| 国产三区精品| 欧美一区二区三区久久精品茉莉花 | 一区二区欧美精品| 欧美日一区二区在线观看| 亚洲综合国产| 欧美国产日韩在线观看| 久久久91精品国产| 欧美日韩精品二区| 欧美国产综合一区二区| 国产精品久久久久秋霞鲁丝 |