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

poj 1200 Crazy Search 字符串hash

   這個題是求一個字符串里面出現了多少個長度為N的不同子串,同時給出了母串里面不同字符
的個數NC。
   保存子串到set里面直接暴力肯定超時了。這個題有個利用字符串hash的解法,雖然理論上有
bug,但是能過這個題。
   利用給出的NC,對長度為N的字符串,將其當作NC進制的數字,求出其值,對值進行hash,
求出不同的hash位置個數。
   這個算法其實類似于Karp-Rabin字符串匹配算法。不過,Karp-Rabin算法做了點改進,對
進制為D的字符串求值的時候為了防止溢出會模一個素數,而且不會每次都迭代求下一個子串的
值,而是從當前子串的值直接遞推出下一個字符的值。怎么遞推了,其實很簡單,就是當前值去
掉最高位再乘以D(相當于左移一位,不過是D進制的,不能直接用<<符號),再加上新的最低位。
   Karp-Rabin算法應該主要在于設計出合理的hash算法,比如,用取模hash函數的話,得保
證hash表足夠大,否則沖突太多,速度就不會怎么好了。比如這個題,hash表小了就AC不了了。

   代碼如下:
#include <stdio.h>
#include <string.h>

const int MAX = 13747347;
int nHash[MAX];
char szStr[17000001];
int nN, nNC;
int nW[200];

void Insert(int nKey)
{
    int nPos = nKey;
    while (nHash[nPos] != -1 && nHash[nPos] != nKey)
    {
        nPos = (nPos + 1) % MAX;
    }
    nHash[nPos] = nKey;
}

bool Find(int nKey)
{
    int nPos = nKey;
    while (nHash[nPos] != -1 && nHash[nPos] != nKey)
    {
        nPos = (nPos + 1) % MAX;
    }
    return nHash[nPos] != -1;
}

int main()
{
    while (scanf("%d%d%s", &nN, &nNC, szStr) == 3)
    {
        memset(nW, 0, sizeof(nW));
        memset(nHash, -1, sizeof(nHash));
        int nNum = 0;
        int nSize = 0;
        for (char* pszStr = szStr; *pszStr; ++pszStr)
        {
            if (!nW[*pszStr])
            {
                nW[*pszStr] = ++nNum;
            }
            ++nSize;
        }

        int nKey = 0;
        int nAns = 0;
        int nPowN = 1;
        for (int j = 0; j < nN; ++j)
        {
            nKey = (nKey * nNC + nW[szStr[j]]) % MAX;
            nPowN *= nNC;
        }
        nPowN /= nNC;
        if (!Find(nKey))
        {
            Insert(nKey);
            nAns++;
        }
        
        for (int i = nN; i < nSize; ++i)
        {
            nKey = (nNC * (nKey - nPowN * nW[szStr[i - nN]])
                    + nW[szStr[i]]) % MAX;
            nKey = (nKey + MAX) % MAX;
            
            if (!Find(nKey))
            {
                Insert(nKey);
                nAns++;
            }
        }
        
        printf("%d\n", nAns);
    }

    return 0;
}

posted on 2012-09-27 22:07 yx 閱讀(1064) 評論(0)  編輯 收藏 引用 所屬分類: 字符串

<2012年9月>
2627282930311
2345678
9101112131415
16171819202122
23242526272829
30123456

導航

統計

公告

常用鏈接

留言簿(3)

隨筆分類

隨筆檔案

me

好友

同學

網友

搜索

最新評論

閱讀排行榜

評論排行榜

青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <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>
            日韩视频欧美视频| 欧美在线视频日韩| 欧美激情女人20p| 欧美www在线| 欧美国产极速在线| 欧美日韩精品一本二本三本| 欧美视频一区二区三区四区| 国产精品区一区二区三| 国产性色一区二区| 亚洲韩国青草视频| 亚洲一区在线看| 久久人体大胆视频| 最新精品在线| 亚洲午夜精品一区二区三区他趣 | 亚洲国产婷婷| 亚洲午夜在线| 麻豆精品在线视频| 国产精品久久久久久久久免费樱桃 | 亚洲精品乱码久久久久久蜜桃91| 一区二区精品在线| 一本色道久久综合| 午夜在线一区| 欧美激情网站在线观看| 在线亚洲成人| 老司机亚洲精品| 国产精品视频九色porn| 亚洲激情成人在线| 久久av一区二区三区漫画| 欧美激情精品久久久久久| 亚洲午夜性刺激影院| 牛牛影视久久网| 国产亚洲综合性久久久影院| 99精品国产福利在线观看免费 | 一区二区欧美在线| 久久精品国产在热久久 | 亚洲国产精品高清久久久| 亚洲女爱视频在线| 欧美极品色图| 在线看成人片| 久久午夜视频| 午夜一区二区三区在线观看| 欧美日韩一区二区三区高清| 亚洲经典自拍| 欧美高清视频www夜色资源网| 欧美一区二区国产| 国产欧美日韩麻豆91| 亚洲欧美日韩专区| 一个色综合导航| 国产精品a级| 亚洲第一黄色网| 亚洲区一区二区三区| 久久五月天婷婷| 激情久久五月| 久久久av毛片精品| 久久精品国产精品亚洲精品| 国产精品亚洲成人| 欧美亚洲视频在线看网址| 在线一区亚洲| 国产精品麻豆va在线播放| 亚洲一区国产视频| 亚洲午夜精品久久久久久浪潮| 欧美日韩一二三区| 亚洲欧美日韩国产一区| 亚洲欧美www| 国产精品欧美日韩一区| 欧美在线精品一区| 欧美影院成人| 亚洲电影在线看| 亚洲国产精品久久| 欧美色欧美亚洲另类二区 | 亚洲一二三区精品| 亚洲图片在区色| 国产日产欧美a一级在线| 亚洲第一精品电影| 一区二区三区在线视频免费观看| 久久精彩免费视频| 久久精品动漫| 亚洲国产一区二区三区a毛片| 免费亚洲电影| 欧美激情中文字幕一区二区| 一区二区欧美激情| 亚洲一区三区电影在线观看| 国产精品自拍一区| 久久久精品国产99久久精品芒果| 久久精品女人的天堂av| 亚洲国产女人aaa毛片在线| 亚洲精品欧美极品| 国产区欧美区日韩区| 欧美大片在线观看| 国产精品成人在线观看| 久久人人精品| 欧美日韩小视频| 久久久久久久久久久久久女国产乱| 久久久亚洲成人| 亚洲一区二区伦理| 久久人人爽人人爽爽久久| 一区二区三区欧美成人| 欧美一区二区三区日韩视频| 日韩午夜激情电影| 欧美制服丝袜| 亚洲欧美国产毛片在线| 久久综合导航| 久久精品成人| 欧美色欧美亚洲另类七区| 毛片一区二区| 国产精品一区二区三区久久久| 欧美韩国日本综合| 亚洲第一精品夜夜躁人人躁| 国产嫩草影院久久久久| 亚洲视频大全| 免费美女久久99| 久久久久久9999| 国产精品高清网站| 亚洲激情第一页| 伊人精品成人久久综合软件| 亚洲天堂免费在线观看视频| 99re亚洲国产精品| 久久全国免费视频| 久久九九有精品国产23| 国产精品久久久久久久久| 亚洲日本在线视频观看| 亚洲国产天堂久久综合| 久久国内精品视频| 久久精品99无色码中文字幕| 国产精品在线看| 亚洲影院免费| 欧美一区二区三区免费看| 国产精品盗摄久久久| 一区二区免费在线播放| 一本色道久久综合精品竹菊 | 欧美猛交免费看| 亚洲国产精品悠悠久久琪琪 | 国产精品久久久久一区二区三区| 亚洲国产美女| 亚洲人体1000| 欧美电影资源| 亚洲国产天堂久久国产91| 亚洲精品免费一二三区| 欧美高清在线观看| 最新成人av网站| 亚洲天堂网站在线观看视频| 欧美三级日本三级少妇99| 99re66热这里只有精品3直播| 亚洲私人影院在线观看| 欧美婷婷在线| 亚洲一区二区成人在线观看| 性亚洲最疯狂xxxx高清| 国产午夜精品理论片a级探花| 欧美一区=区| 欧美va天堂| 99精品免费| 国产精品青草久久久久福利99| 午夜精品久久久久99热蜜桃导演| 久久精品综合一区| 亚洲欧洲一区二区三区| 欧美日韩国产精品专区| 一区二区三区日韩精品| 欧美专区在线| 亚洲激情在线视频| 欧美日韩亚洲激情| 亚洲欧美韩国| 欧美成ee人免费视频| 一本色道久久综合亚洲91| 国产精品一区久久久| 久久综合狠狠综合久久综青草| 欧美激情一区二区在线 | 亚洲激情电影在线| 亚洲一级特黄| 一区视频在线| 国产精品高潮呻吟视频| 久久精品国产一区二区三区| 91久久香蕉国产日韩欧美9色| 午夜伦欧美伦电影理论片| 精品成人久久| 久久久久久久久蜜桃| 亚洲欧洲美洲综合色网| 国产精品成人一区二区网站软件 | 亚洲精品一区二区三区不| 国产精品高清一区二区三区| 久久综合伊人77777| 亚洲在线成人| 亚洲国产专区校园欧美| 欧美在线日韩| 一区二区三区欧美| 亚洲电影免费| 国产一区二区精品久久| 欧美性猛交99久久久久99按摩| 久久男人资源视频| 亚洲欧美日本国产有色| 亚洲人线精品午夜| 欧美ab在线视频| 久久久蜜桃一区二区人| 午夜精品美女久久久久av福利| 日韩视频在线免费| 在线成人性视频| 国产亚洲欧洲一区高清在线观看| 国产精品www色诱视频| 欧美日韩午夜视频在线观看| 欧美成人在线网站| 牛人盗摄一区二区三区视频|