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

ZOJ 1808 Immediate Decodability

Posted on 2010-11-05 17:12 李東亮 閱讀(1306) 評論(0)  編輯 收藏 引用 所屬分類: acm
 

ZOJ 1808 Immediate Decodability

       這道題給出n個有10組成的字符串集合,然后要求判斷是否有某一個字符串是另一個字符串的前綴。是字典樹的典型應用。

       字典樹有靜態和動態之分,動態字典樹就是在插入時根據需要動態malloc節點,而靜態字典樹則是事先開辟一個較大的數組,然后設置一個變量index指向當前數組中未被占用的節點下標的最小值,即下一個可用節點的下標。跟C語言中實現靜態鏈表類似。這兩種方法各有優劣,動態字典樹理論上可以插入任意多個節點,但是每次的malloc及最后的free會消耗很多時間。而靜態字典樹省去了內存的動態申請和釋放,節省了時間,但是可以插入節點數目受到事先開辟的數組大小限制,可擴展性較差。具體采用哪種實現方式根據需求而定。就本題而言時間要求1s,可以初步需要插入的判斷節點數目不會太多,因此為了提高運行速度采用了靜態字典樹。

       參考代碼如下:

#include <stdio.h>
#include 
<stdlib.h>
#include 
<string.h>
struct dick
{
    
/*左右孩子指針,指向左右孩子在數組中的下標,做孩子為0,右孩子為1*/
    
int child[2];
    
/*是否是字符串的最后一個字符*/
    
int leaf;
};
/*從該數組中分配節點*/
struct dick d[1000];
/*指向下個可用節點的下標*/
int index;
int main(void)
{
    
char buf[100];
    
int no = 0;
    
int flag = 1;
    
int i;
    index 
= 0;
    
int start;
    
int tmp;
    
int test;
    memset(d, 
0sizeof(d));
    freopen(
"in.txt""r", stdin);
    
while (gets(buf) != NULL)
    {
        
if (buf[0== '9' && buf[1]  == '\0')
        {
            
++no;
            
if (flag == 1)
            {
                printf(
"Set %d is immediately decodable\n", no);
            }
            
else
            {
                printf(
"Set %d is not immediately decodable\n", no);
            }
            
/*清理和初始化數據*/
            flag 
= 1;
            memset(d, 
0sizeof(d));
            index 
= 0;
        }
        
else if (flag == 1)
        {
            i 
= 0
            start 
= 0;
            test 
= 1;
            
/*逐字符插入數據到字典樹中*/
            
while (buf[i] != '\0')
            {
                
if (d[start].child[buf[i]-'0'== 0)
                {
                    
if (d[start].leaf == 1)
                    {
                        
break;/*發現已插入字符串是本字符串的前綴*/
                    }
                    
/*分配新的節點*/
                    d[start].child[buf[i]
-'0'= ++index;
                    test 
= 0;                    
                }
                tmp 
= d[start].child[buf[i]-'0'];
                
if (buf[i+1== '\0')
                {
                    d[tmp].leaf 
= 1;
                }
                start 
= tmp;                
                
++i;
            }
            
if (test == 1)
            {
                flag 
= 0;
            }
        }
    }
    
return 0;
}

posts - 12, comments - 1, trackbacks - 0, articles - 1

Copyright © 李東亮

青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <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电影| 国产欧美一区二区白浆黑人| 欧美在现视频| 久久久蜜臀国产一区二区| 在线免费一区三区| 亚洲清纯自拍| 欧美色播在线播放| 久久国产加勒比精品无码| 久久精品天堂| 亚洲精品看片| 亚洲一区二区av电影| 国产一区二区精品久久99| 蜜桃av综合| 欧美午夜精品久久久久久浪潮| 亚洲欧美亚洲| 你懂的成人av| 午夜免费久久久久| 久久一综合视频| 日韩亚洲一区二区| 久久国产加勒比精品无码| 亚洲日本中文字幕免费在线不卡| 9久草视频在线视频精品| 狠狠色狠狠色综合日日91app| 欧美国产专区| 国产日韩欧美在线| 亚洲精品网站在线播放gif| 国产热re99久久6国产精品| 亚洲国产综合91精品麻豆| 国产精品亚洲综合一区在线观看| 美女视频黄a大片欧美| 国产精品久久久久久模特| 欧美插天视频在线播放| 国产精品黄色| 亚洲国产精彩中文乱码av在线播放| 国产精品国产成人国产三级| 亚洲高清自拍| 国模叶桐国产精品一区| 亚洲视频精品| 一区二区欧美在线观看| 久久免费精品视频| 久久免费黄色| 国产欧美日韩伦理| av成人福利| 亚洲精品视频二区| 老司机免费视频久久| 欧美在线精品免播放器视频| 欧美日韩在线大尺度| 欧美激情第4页| 在线观看久久av| 欧美与黑人午夜性猛交久久久| 亚洲综合精品一区二区| 欧美日韩综合| 日韩一级片网址| 亚洲免费精彩视频| 暖暖成人免费视频| 欧美不卡激情三级在线观看| 黄网动漫久久久| 久久福利精品| 老司机午夜精品| 好吊日精品视频| 久久精彩视频| 久久亚洲国产精品一区二区 | 午夜视频在线观看一区| 亚洲午夜av在线| 欧美色视频一区| 中文av字幕一区| 亚洲欧美综合一区| 国产欧美日韩亚州综合| 亚洲欧美在线一区| 久久另类ts人妖一区二区| 国产偷自视频区视频一区二区| 香蕉久久国产| 毛片一区二区三区| 亚洲国产精品欧美一二99| 欧美精品1区| 一区二区三区免费网站| 亚洲欧美一区二区原创| 国产一区二区精品久久99| 久久久免费av| 亚洲精品日韩一| 欧美一区二区网站| 亚洲福利专区| 欧美日韩国产一区二区| 亚洲午夜在线观看| 久久久久.com| 日韩视频在线你懂得| 国产精品久久二区二区| 久久国产毛片| 亚洲日本在线视频观看| 亚洲欧美精品一区| 亚洲福利视频三区| 欧美日韩一区二区在线观看视频| 亚洲一区制服诱惑| 欧美风情在线| 欧美伊人影院| 亚洲精选视频免费看| 国产精品在线看| 开心色5月久久精品| 一本色道久久综合一区| 麻豆成人综合网| 亚洲欧美经典视频| 亚洲欧洲另类国产综合| 国产精品网站一区| 久久久亚洲成人| 宅男噜噜噜66一区二区| 欧美国产视频在线| 久久爱www久久做| 在线视频亚洲欧美| 亚洲国产经典视频| 国产精品久久影院| 欧美乱大交xxxxx| 久久久国产一区二区| 亚洲最新视频在线播放| 欧美成人亚洲成人| 久久精品国产一区二区三| 一区二区三区四区精品| 亚洲国产精品传媒在线观看 | 国产精品高清一区二区三区| 久久久噜噜噜久久| 亚洲欧美三级在线| 99在线|亚洲一区二区| 欧美高清视频一区二区| 久久先锋影音| 欧美在线免费观看| 亚洲欧美一区二区在线观看| 亚洲日本一区二区三区| 在线电影国产精品| 国产一区二区中文| 国产日产欧产精品推荐色| 国产精品成人免费| 欧美日韩亚洲不卡| 欧美日韩亚洲高清一区二区| 欧美激情亚洲另类| 欧美电影免费观看高清完整版| 久久综合电影一区| 久久米奇亚洲| 噜噜爱69成人精品| 久久久综合网| 久久亚洲二区| 蜜桃伊人久久| 欧美国产精品| 欧美精品免费播放| 欧美精品一区二区三区久久久竹菊| 老司机免费视频久久| 欧美 日韩 国产一区二区在线视频| 久久亚洲一区二区| 蜜臀99久久精品久久久久久软件 | 亚洲美女av网站| 亚洲九九精品| 一区二区精品| 午夜欧美精品久久久久久久| 欧美一区二区三区在| 欧美一区二区三区四区在线观看| 欧美中文字幕在线观看| 久久午夜色播影院免费高清| 欧美a级片网| 欧美日韩一级黄| 国产精品一区在线播放| 国产一区二区三区高清在线观看 | 亚洲精品视频免费在线观看| 亚洲毛片播放| 亚洲一区二区在线免费观看| 欧美主播一区二区三区美女 久久精品人 | 亚洲日韩第九十九页| 一区二区三区免费网站| 亚洲欧美日韩一区在线| 老司机免费视频一区二区| 亚洲精品1区| 亚洲欧美日韩专区| 老司机免费视频久久| 欧美日韩免费| 经典三级久久| 一本色道久久综合亚洲91| 欧美专区第一页| 亚洲福利视频免费观看| 亚洲一区二区少妇| 麻豆久久久9性大片| 国产精品www色诱视频| 精品不卡一区二区三区| 一本色道久久综合狠狠躁篇的优点 | 99视频一区| 久久久噜久噜久久综合| 亚洲精品偷拍| 久久久亚洲影院你懂的| 国产精品男女猛烈高潮激情| 亚洲第一色在线| 久久成人精品电影| 亚洲日本欧美| 久久综合久久美利坚合众国| 欧美丝袜第一区| 亚洲欧洲精品一区二区三区| 久久久久久伊人| 一区二区久久久久| 欧美日本亚洲| 亚洲激情一区二区| 久久综合网络一区二区|