亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關(guān)于我們
? 蟲蟲下載站

?? untitled1.cpp

?? 中文分詞程序
?? CPP
字號(hào):
/*中文分詞使用整數(shù)進(jìn)行判斷*/
/**//*在目錄下的word-.txt是中文詞的文件*/
/**//*程序?qū)ν荒夸浵碌膕plit.txt進(jìn)行分割*/
/**//*程序?qū)崿F(xiàn):
/*第一個(gè)中文字用數(shù)組進(jìn)行查找,之后進(jìn)行森林的搜索*/
#include <stdio.h>
#include <malloc.h>
#include <ctype.h>
#include <string.h>
#include <windows.h>
typedef struct Trie/**//*森林的結(jié)構(gòu)*/
{
    long int value;
    struct Trie *child,*sibling;
    int eof;/**//*中文詞的標(biāo)記*/
}Trie;   
Trie *HashTable[65536]={NULL};/**//*第一個(gè)字的根結(jié)點(diǎn)用數(shù)組存儲(chǔ)*/
Trie *search(Trie *root,int value)
/**//*在此層進(jìn)行文字的查找*/
{
    if(root==NULL)
        return root;
    else
    {
        root=root->child;
        while(root&&(root->value!=value))
          root=root->sibling;
        return root;
    }
}
Trie *insert(Trie *root,int value)
{
    Trie *tmpcell,*tmp;
    if(root->child==NULL)
    {
        tmpcell=(Trie*)malloc(sizeof(Trie));
        tmpcell->value=value;
        tmpcell->child=NULL;
        tmpcell->sibling=NULL;
        tmpcell->eof=0;
        root->child=tmpcell;
        return tmpcell;
    }
    else
    {
        tmp=root->child;
        while(tmp&&(tmp->value!=value))
        {
            root=tmp;
            tmp=tmp->sibling;
        }
        if(tmp)return tmp;
        else
        {
            tmpcell=(Trie*)malloc(sizeof(Trie));
            tmpcell->value=value;
            tmpcell->child=NULL;
            tmpcell->sibling=NULL;
            tmpcell->eof=0;
            root->sibling=tmpcell;
            return tmpcell;
        }
    }
}
void create()/**//*建立索引*/
/**//*結(jié)構(gòu)很簡單,但很難描述*/
/**//*中文字第一層用hash查找并找到根,后面用森林進(jìn)行查找*/
{
    FILE *fp;
    int words=2,maxwords=20,i;
    char *filename="word.txt"; 
    //char filename[10]={0};
    char sequence[4]={0};
    unsigned char buffer[40]={0};
    long int value;
    Trie *root,*tmpcell;
    for(words=2;words<=maxwords;words+=2)
    {
        //strcpy(filename,"word");
        //itoa(words,sequence,10);
        //strcat(filename,sequence);
        //strcat(filename,".txt");/**//*構(gòu)造詞文件名*/
        fp=fopen(filename,"r");
        if(fp==NULL)
            continue;
        while(!feof(fp))
        {
            fscanf(fp,"%s ",buffer);
            value=buffer[0];
            value=value<<8;
            value+=buffer[1];
            if(HashTable[value]==NULL)
            {
                tmpcell=(Trie*)malloc(sizeof(Trie));
                tmpcell->value=value;
                tmpcell->child=NULL;
                tmpcell->sibling=NULL;
                tmpcell->eof=0;
                HashTable[value]=tmpcell;
            }
            root=HashTable[value];
            for(i=2;i<=words-2;i+=2)
            {
                value=buffer[i];
                value=value<<8;
                value+=buffer[i+1];
                root=insert(root,value);
            }
            root->eof=1;
        }
        fclose(fp);
    }
}
void freetrie(Trie *root)
/**//*遞歸釋放森令各節(jié)點(diǎn)*/
{
    Trie *tmp;
    if(root==NULL)
        return ;
    else
    {
        tmp=root->sibling;
        freetrie(root->child);
        free(root);
        freetrie(tmp);
    }
}
void freehash()/**//*釋放hash和后面的根*/
{
    int i;
    Trie *root;
    for(i=0;i<65536;i++)
    {    
        root=HashTable[i];
        if(root!=NULL)
            freetrie(root);
    }
}
void fsplit(char *filename)
{
    int lasteof=0/**//*記錄最后一個(gè)匹配的詞*/,str_pos=0/**//*str的位置*/,value;
    unsigned char str[20]={0},ch[2]={0};
    Trie *root;
    FILE *fp=fopen(filename,"r");
    
    if(fp==NULL)
    {
        printf("No file ");
        return ;
    }
    while(!feof(fp))
    {
        ch[0]=fgetc(fp);
        if(ch[0]<128)/**//*非中文字符直接輸出*/
        /**//*并將前面匹配的中文詞輸出*/
        {
            str[str_pos]=0;
            printf("%s",str);
            str_pos=0;
            //putchar(ch[0]);
        }
        else
        {
            ch[1]=fgetc(fp);/**//*若非種文字符需要讀兩個(gè)字節(jié)*/
            value=ch[0];
            value=value<<8;
            value+=ch[1];
            if(str_pos==0)
            {
                root=HashTable[value];
                str[str_pos++]=ch[0];
                str[str_pos++]=ch[1];
                lasteof=2;
            }
            else
            {
                root=search(root,value);
                if(root==NULL)/**//*沒有匹配*/
                {
                    str[lasteof]=0;
                    printf("%s ",str);
                    if(str_pos!=2)/**//*這部分很重要*/
                    /**//*根據(jù)str_pos和lasteof作適當(dāng)?shù)幕赝?/
                    {
                         if(str_pos==lasteof)
                                   fseek(fp,-2,SEEK_CUR);
                         else
                                   fseek(fp,-(str_pos-lasteof),SEEK_CUR);
                    }
                    else
                         fseek(fp,-2,SEEK_CUR);    
                    str_pos=0;
                }
                else/**//*若匹配直接存儲(chǔ)*/
                {
                    str[str_pos++]=ch[0];
                    str[str_pos++]=ch[1];
                    if(root->eof==1)/**//*若是一個(gè)中文詞,記錄下最后的位置*/
                        lasteof=str_pos;
                }
            }
        }        
    }
    fclose(fp);
    return ;
}
int main()
{
    char *filename="split.txt"; 
    DWORD time[2];
    create();
    
    fsplit(filename);
    
    freehash();
    getchar();
    return 0;
}

?? 快捷鍵說明

復(fù)制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號(hào) Ctrl + =
減小字號(hào) Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
91亚洲精品一区二区乱码| 久久69国产一区二区蜜臀| 粉嫩av亚洲一区二区图片| 久久精品夜夜夜夜久久| 成人天堂资源www在线| 中文字幕一区二区三区蜜月| 色哟哟一区二区三区| 亚洲黄色性网站| 欧美精品日韩一本| 精品一区二区三区免费播放| 中文字幕的久久| 91黄视频在线| 久久成人综合网| 中文字幕欧美国产| 日本电影亚洲天堂一区| 日本中文一区二区三区| 久久精品视频一区| 在线免费观看成人短视频| 日韩电影免费在线| 国产三级精品三级在线专区| 91美女在线视频| 日本亚洲欧美天堂免费| 欧美国产丝袜视频| 欧美日韩精品欧美日韩精品一| 精品亚洲国内自在自线福利| 国产精品不卡在线观看| 在线不卡欧美精品一区二区三区| 国产毛片一区二区| 亚洲成人av中文| 欧美国产国产综合| 欧美精品丝袜久久久中文字幕| 国产精品99久| 婷婷综合五月天| 国产精品理伦片| 欧美一区二区三区在线视频| 成人av电影在线播放| 免费成人在线观看视频| 亚洲精品欧美二区三区中文字幕| 欧美成人a视频| 欧美亚洲精品一区| 懂色av一区二区三区蜜臀| 日韩av一级电影| 一区二区三区高清| 国产精品美女久久久久aⅴ国产馆 国产精品美女久久久久av爽李琼 国产精品美女久久久久高潮 | 天堂精品中文字幕在线| 中文字幕欧美激情| 精品伦理精品一区| 欧美日韩黄色影视| 在线亚洲免费视频| 成人av网站在线观看免费| 久久国产日韩欧美精品| 亚洲第一狼人社区| 日韩毛片视频在线看| 久久先锋影音av鲁色资源网| 在线播放国产精品二区一二区四区| 99热国产精品| 成人高清免费在线播放| 国内外精品视频| 麻豆成人免费电影| 日韩黄色免费电影| 午夜影视日本亚洲欧洲精品| 国产精品久久久久久久久免费丝袜| 精品国产乱码久久久久久浪潮| 欧美另类videos死尸| 欧美性感一类影片在线播放| 一本久久综合亚洲鲁鲁五月天 | 亚洲视频综合在线| 国产精品久久综合| 欧美激情艳妇裸体舞| 国产亚洲成aⅴ人片在线观看| 欧美成人一区二区三区| 日韩欧美视频在线| 欧美一区二区三区的| 日韩亚洲电影在线| 日韩色在线观看| 日韩精品一区二区在线观看| 欧美一区二区视频在线观看2020 | 久久www免费人成看片高清| 奇米影视在线99精品| 美国欧美日韩国产在线播放| 男男gaygay亚洲| 久久精品国产99国产| 国内精品免费**视频| 国产精品白丝jk黑袜喷水| 黑人巨大精品欧美黑白配亚洲 | www.欧美精品一二区| jlzzjlzz亚洲日本少妇| 91在线免费看| 色成年激情久久综合| 欧美日韩一区二区三区在线| 欧美日韩成人在线| 欧美mv和日韩mv国产网站| 久久久久久久久久久久久夜| 国产精品理伦片| 一区av在线播放| 蜜桃精品视频在线| 国产成人精品午夜视频免费| 99久久99精品久久久久久| 91看片淫黄大片一级在线观看| 欧美亚洲一区二区三区四区| 日韩一级二级三级| 国产欧美日韩亚州综合| 亚洲人123区| 日本成人超碰在线观看| 国产精品系列在线观看| 在线欧美日韩国产| 日韩免费看的电影| 国产精品视频一二三区| 亚洲成在线观看| 精品亚洲免费视频| 91国偷自产一区二区开放时间| 在线不卡一区二区| 日本一区二区三区免费乱视频| 国产精品久久久99| 日韩黄色免费网站| 99久久国产综合精品色伊| 欧美精品一级二级三级| 日本一区二区免费在线| 五月婷婷激情综合网| 国产成人一区在线| 777色狠狠一区二区三区| 中文字幕 久热精品 视频在线 | 国内精品伊人久久久久av影院| 成人精品鲁一区一区二区| 欧美精品日日鲁夜夜添| 国产精品久久福利| 久久国产欧美日韩精品| 91久久线看在观草草青青| 欧美va天堂va视频va在线| 亚洲影院久久精品| 成人午夜在线视频| 日韩小视频在线观看专区| 亚洲精品免费一二三区| 国产91精品在线观看| 337p亚洲精品色噜噜| 亚洲精品成人精品456| 国产高清精品在线| 日韩欧美国产综合在线一区二区三区 | 97久久超碰精品国产| 久久久久久久精| 蜜臀久久久99精品久久久久久| 日本精品视频一区二区三区| 国产欧美一二三区| 精品一区二区三区久久久| 欧美久久高跟鞋激| 亚洲国产一区在线观看| 99久久久国产精品| 亚洲国产成人午夜在线一区| 精油按摩中文字幕久久| 欧美一区二区三区四区五区| 一区二区三区中文在线观看| 成人黄色免费短视频| 久久精品一区二区三区av | eeuss影院一区二区三区 | 色婷婷精品大视频在线蜜桃视频| 国产日产欧美一区二区三区| 蜜桃精品在线观看| 日韩一卡二卡三卡| 久久99久国产精品黄毛片色诱| 欧美精品tushy高清| 亚洲成人三级小说| 欧美日韩三级一区| 亚洲chinese男男1069| 欧美男男青年gay1069videost | 91老司机福利 在线| 亚洲视频在线一区观看| 色呦呦国产精品| 亚洲国产精品久久久男人的天堂| 色网综合在线观看| 亚洲一区二区偷拍精品| 在线精品观看国产| 午夜精品爽啪视频| 欧美一区永久视频免费观看| 日韩精品乱码av一区二区| 91精品午夜视频| 久久精品国产77777蜜臀| 日韩免费电影网站| 国产精品资源站在线| 国产喷白浆一区二区三区| 国产不卡在线播放| 1024亚洲合集| 欧美三级在线看| 美洲天堂一区二卡三卡四卡视频| 精品电影一区二区| 成人性生交大片免费看在线播放| 国产精品丝袜91| 欧美日韩一区二区欧美激情| 青青草国产精品亚洲专区无| 久久久久久久电影| 一本色道久久综合亚洲精品按摩| 亚洲午夜久久久久久久久久久 | 一本一道久久a久久精品| 亚洲一区二区欧美| 日韩视频一区二区在线观看| 国产精品亚洲综合一区在线观看| 亚洲少妇30p| 欧美一区二区视频网站| 国产91精品久久久久久久网曝门| 亚洲美女偷拍久久| 欧美成人性战久久|