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

學習心得(code)

superlong@CoreCoder

  C++博客 :: 首頁 :: 聯系 :: 聚合  :: 管理
  74 Posts :: 0 Stories :: 5 Comments :: 0 Trackbacks

公告

文字可能放在http://blog.csdn.net/superlong100,此處存放代碼

常用鏈接

留言簿(4)

我參與的團隊

搜索

  •  

最新隨筆

最新評論

  • 1.?re: Poj 1279
  • 對于一個凹多邊形用叉積計算面積 后能根據結果的正負來判斷給的點集的時針方向?
  • --bsshanghai
  • 2.?re: Poj 3691
  • 你寫的這個get_fail() 好像并是真正的get_fail,也是說fail指向的串并不是當前結點的子串。為什么要這樣弄呢?
  • --acmer1183
  • 3.?re: HDU2295[未登錄]
  • 這個是IDA* 也就是迭代加深@ylfdrib
  • --superlong
  • 4.?re: HDU2295
  • 評論內容較長,點擊標題查看
  • --ylfdrib
  • 5.?re: HOJ 11482
  • 呵呵..把代碼發在這里很不錯..以后我也試試...百度的編輯器太爛了....
  • --csuft1

閱讀排行榜

評論排行榜

#include <iostream>
#include 
<string.h>
using namespace std;

struct tree
{
    tree 
*next[26], *fail;
    
int flag, len, ;
};

tree 
*root, *p;
tree arr[
500001];
int  indexx;
char letter = 'a';

void newn()
{
    arr[indexx].fail 
= NULL;
    arr[indexx].flag 
= 0;
    arr[indexx].len 
= -1;
    
for(int i = 0; i < 26; i ++) arr[indexx].next[i] = 0;
}

void insert(char ch[], int w)
{
    p 
= root;
    
int tmp, i = 0;
    
while(ch[i])
    {
        tmp 
= ch[i] - letter;
        
if(p->next[tmp] == 0)
        {
            newn();
            p
->next[tmp] = &arr[indexx ++];
            p
->next[tmp]->len = p->len + 1;
        }
        p 
= p->next[tmp];
        i 
++;
    }
    
if(!p->flag)
        p
->flag = w;
}

tree 
*que[500005];

void get_fail()
{
    p
=root;
    p
->fail = root;
    
int open = 0, close = -1, i;
    que[
0= p;
    
while(close < open)
    {
        p 
= que[++ close];
        
for(i = 0; i < 26; i ++)
        {
            
if(p->next[i] == 0
            {
                
if(p == root)    p->next[i] = root;
                
else            p->next[i] = p->fail->next[i];
            }
            
else
            {
                
if(p == root)    p->next[i]->fail = root;
                
else            p->next[i]->fail = p->fail->next[i];
                que[
++open] = p->next[i];
            }
        }
    }
}

int ans[2][100005];
int pos[100005];

void query(char ch[])
{
    p 
= root;
    tree 
*q;
    
int t, i = 0;
    
while(ch[i])
    {
        t 
= ch[i] - letter;
        p 
= p->next[t];
        q 
= p;
        
while(q != root && q->fail )
        {
            
if(q->flag)
            {
                ans[
0][q->flag] ++;
                
if(i - pos[q->flag] > q->len)
                {
                    ans[
1][q->flag] ++;
                    pos[q
->flag] = i;
                }
            }
            q 
= q->fail;
        }
        i 
++;
    }
}

int search(char ch[])
{
    p 
= root;
    
int tmp, i = 0;
    
while(ch[i])
    {
        tmp 
= ch[i] - letter;
        p 
= p->next[tmp];
        i 
++;
    }
    
return p->flag;
}

void init()
{
    indexx 
= 0;
    newn();
    root 
= &arr[indexx ++];
    memset(ans, 
0sizeof(ans));
    memset(pos, 
-1sizeof(pos));
}

char str[100005];
char dic[100005][7];
int  typed[100005];

int main()
{
    
int test = 0;
    
while(scanf("%s", str) != EOF)
    {
        
int n, i;
        init();
        scanf(
"%d"&n);
        
for(i = 1; i <= n; i ++)
        {
            scanf(
"%d %s"&typed[i], dic[i]);
            insert(dic[i], i);
        }
        get_fail();
        query(str);
        printf(
"Case %d\n",++test);
        
for(i = 1; i <= n; i ++)
        {
            
int id = search(dic[i]);
            printf(
"%d\n", ans[typed[i]][id]);
        }
        puts(
"");
    }
}

posted on 2009-09-08 12:17 superlong 閱讀(468) 評論(0)  編輯 收藏 引用
青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <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大片| 亚洲一区免费| 国产精品久久一区主播| 亚洲综合视频一区| 亚洲午夜精品一区二区| 国产区在线观看成人精品| 久久久久久久久久久久久女国产乱 | 久久精品免费看| 亚洲国产精彩中文乱码av在线播放| 女主播福利一区| 欧美另类一区| 久久成人久久爱| 欧美/亚洲一区| 亚洲欧美中日韩| 久久这里只有精品视频首页| av成人天堂| 欧美一区二区三区日韩视频| 最新亚洲视频| 亚洲视频一区二区免费在线观看| 国产一区二区av| 91久久精品久久国产性色也91| 欧美三级韩国三级日本三斤| 欧美一区二区黄色| 久久亚洲精选| 欧美一级专区免费大片| 免费不卡亚洲欧美| 久久av二区| 欧美精品一区在线| 久久夜色精品国产欧美乱极品 | 国产精品99久久久久久白浆小说| 韩国精品一区二区三区| 亚洲靠逼com| 在线观看亚洲一区| 亚洲欧美不卡| av成人动漫| 久久全国免费视频| 欧美呦呦网站| 欧美色欧美亚洲另类二区 | 亚洲一区二区三区四区在线观看| 久久成人综合网| 亚洲综合欧美| 欧美人与禽猛交乱配视频| 欧美日韩xxxxx| 免费日韩精品中文字幕视频在线| 国产精品乱码妇女bbbb| 欧美黑人在线播放| 18成人免费观看视频| 亚洲制服丝袜在线| 亚洲伊人观看| 欧美日韩一区二区在线| 亚洲激情专区| 亚洲国产视频一区| 久久色在线播放| 久久五月天婷婷| 激情成人综合| 欧美在线视频不卡| 久久精品一二三区| 国产一区二区电影在线观看 | 亚洲一区在线直播| 亚洲男女自偷自拍图片另类| 欧美日韩另类一区| 亚洲精选91| 在线一区二区三区四区| 欧美日韩综合视频| 一区二区三区高清视频在线观看| 99国产精品99久久久久久粉嫩| 欧美不卡视频一区发布| 欧美黄色一区二区| 日韩午夜三级在线| 欧美午夜精品一区| 亚洲网站视频福利| 久久国产精品电影| 狠狠色狠狠色综合系列| 久久久久久久91| 亚洲第一伊人| 夜夜爽www精品| 国产精品看片你懂得| 欧美在线观看视频一区二区| 久久精品在线观看| 亚洲国产精品视频一区| 欧美精品一区二区视频| 一区二区三区av| 久久精品视频99| 在线日韩av| 欧美精品一区在线观看| 亚洲在线电影| 欧美成人一品| 亚洲女人天堂av| 一区精品在线播放| 欧美日韩精品在线| 欧美在线观看视频一区二区| 欧美黄色成人网| 午夜精彩视频在线观看不卡| 国产在线视频欧美| 欧美精品一区二区久久婷婷| 一本色道久久综合亚洲二区三区| 欧美中文在线观看国产| 亚洲国产裸拍裸体视频在线观看乱了 | 亚洲韩日在线| 亚洲欧美日韩一区| 亚洲激情不卡| 国产欧美日韩精品丝袜高跟鞋| 久久综合狠狠综合久久激情| aⅴ色国产欧美| 欧美电影电视剧在线观看| 亚洲欧美春色| 亚洲精品五月天| 好吊妞这里只有精品| 欧美日韩亚洲一区| 久久久蜜桃一区二区人| 亚洲图片欧美一区| 亚洲狠狠婷婷| 久热精品视频在线观看一区| 亚洲一区二区在线播放| 亚洲成色最大综合在线| 国产区二精品视| 国产精品久久久久三级| 欧美激情偷拍| 欧美va亚洲va国产综合| 欧美在线免费一级片| 亚洲欧美春色| 一区二区三区黄色| 亚洲国产高清视频| 免费在线成人av| 久久婷婷国产麻豆91天堂| 午夜精品美女久久久久av福利| 亚洲美女精品久久| 亚洲国产天堂久久国产91| 国产亚洲一区二区三区| 国产精品视频不卡| 欧美视频官网| 欧美日韩视频在线一区二区观看视频| 久久综合给合| 美女日韩欧美| 欧美 亚欧 日韩视频在线| 久久这里有精品视频 | 亚洲精品乱码久久久久久久久| 老司机午夜精品| 开元免费观看欧美电视剧网站| 性感少妇一区| 欧美一区二区播放| 欧美在线观看视频一区二区| 午夜视频一区在线观看| 欧美亚洲专区| 久久精品夜色噜噜亚洲aⅴ| 久久久国产成人精品| 久久综合色播五月| 欧美激情亚洲自拍| 亚洲娇小video精品| 日韩一区二区精品| 一区二区激情| 午夜亚洲一区| 久久综合伊人77777麻豆| 蜜臀av在线播放一区二区三区| 毛片av中文字幕一区二区| 欧美成人午夜剧场免费观看| 欧美精品黄色| 国产精品免费小视频| 狠狠色狠狠色综合人人| 亚洲欧洲一区二区三区在线观看| 亚洲美女啪啪| 午夜精品一区二区三区四区| 久久国产日本精品| 欧美/亚洲一区| 99精品视频免费| 欧美在线视频观看免费网站| 久久综合亚洲社区| 欧美午夜不卡视频| 好吊成人免视频| 亚洲天堂偷拍| 麻豆成人精品| 亚洲另类黄色| 久久久久国产精品厨房| 欧美久久在线| 精品999在线播放| 亚洲视频一起| 欧美成va人片在线观看| 一区二区电影免费观看| 久久精品国产亚洲5555| 欧美日韩1080p| 黄色欧美日韩| 亚洲一区综合| 亚洲精品1区2区| 久久黄色级2电影| 欧美三级第一页| 亚洲国产三级网| 久久久久久久综合| 一区二区三区国产| 你懂的国产精品| 国产一区二区三区高清在线观看 | 午夜亚洲伦理| 亚洲人成在线观看| 久久久久久久激情视频| 国产精品免费福利| 日韩午夜电影在线观看| 免费一级欧美在线大片| 亚洲欧美中文另类| 国产精品久久久久久av下载红粉| 亚洲美女黄网|