• <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>
            posts - 195,  comments - 30,  trackbacks - 0

            這是第一種哈希函數(shù),運行時間短,但內(nèi)存占用多。哈希函數(shù)是怎么得到的?我也想知道。。。
            #include<stdio.h>
            #include<string.h>
            #include<math.h>
            struct abc
            {
                int boo;
                char key[12];
            }hash[1100005];
            int const prime=999983;
            double const gold=0.618033;
            void insert(char a[],int k,int w)
            {
                if(hash[w].boo==0)
                {   
                    hash[w].boo=k;
                    memcpy(hash[w].key,a,sizeof(hash[w].key));
                }
                else
                    insert(a,k,w%prime+1);    
            }
            int find(int k,int w)
            {
                if(hash[w].boo==k)
                {
                    printf("%s\n",hash[w].key);
                        return 1;
                }   
                else
                {
                    if(hash[w].boo==0)
                        return 0;
                    else
                        return find(k,w%prime+1);
                }   
            }
            int main()
            {
                freopen("in.txt","r",stdin);
                char a[12],b[12];
                scanf("%c",&a[0]);
                while(scanf("%s%s",a+1,b))
                {
                    getchar();
                    int len=strlen(b);
                    int k=0;
                    for(int i=0;i<len;i++)
                        k=k*26+b[i]-'a';
                    int w=int (prime*(k*gold-floor(k*gold)));
                    insert(a,k,w);
                    scanf("%c",&a[0]);
                    if(a[0]=='\n')
                        break;
                }
                while(scanf("%s",&a)==1)
                {
                    int len=strlen(a);
                    int k=0;
                    for(int i=0;i<len;i++)
                    k=k*26+a[i]-'a';
                    int w=int (prime*(k*gold-floor(k*gold)));
                    if(find(k,w)==0)
                    printf("eh\n");
                }
                return 0;
            }
            這是用書中提到的ELFhash()函數(shù),也沒體現(xiàn)出時間上的優(yōu)勢,但空間上確實是省了不少,可能是計算ELFhash()時浪費了時間吧,處理字符串哈希沖突的辦法目前只發(fā)現(xiàn)了線形探測法,雖然不理想,但愿將來能發(fā)現(xiàn)別的辦法。
            ELFhash函數(shù)在UNIX系統(tǒng)V 版本4中的“可執(zhí)行鏈接格式”( Executable and Linking Format,即ELF )中會用到,ELF文件格式用于存儲可執(zhí)行文件與目標(biāo)文件。ELFhash函數(shù)是對字符串的散列。它對于長字符串和短字符串都很有效,字符串中每個字符都 有同樣的作用,它巧妙地對字符的ASCII編碼值進(jìn)行計算,ELFhash函數(shù)對于能夠比較均勻地把字符串分布在散列表中。
            #include<stdio.h>
            #include<string.h>
            #include<math.h>
            #define MOD 300005
            struct abc
            {
                bool boo;
                char akey[12];
                char bkey[12];
            }hash[300005];

            int ELFhash(char *key)
            {
                unsigned long h=0;
                while(*key)
                {
                    h=(h<<4)+*key++;
                    unsigned long g=h&0Xf0000000L;
                    if(g) h^=g>>24;
                    h&=~g;
                }
                return h%MOD;
            }
            void insert(char a[],char b[],int w)
            {
                if(!hash[w].boo)
                {   
                    hash[w].boo=true;
                    memcpy(hash[w].akey,a,sizeof(hash[w].akey));
                    memcpy(hash[w].bkey,b,sizeof(hash[w].bkey));
                }
                else
                    insert(a,b,w+1);    
            }
            int find(char b[],int w)
            {
                if(hash[w].boo && strcmp(hash[w].bkey,b)==0)
                {
                    printf("%s\n",hash[w].akey);
                        return 1;
                }   
                else
                {
                    if(!hash[w].boo)
                        return 0;
                    else
                        return find(b,w+1);
                }   
            }
            int main()
            {
                char a[12],b[12];
                scanf("%c",&a[0]);
                while(scanf("%s%s",a+1,b))
                {
                    getchar();
                    int w=ELFhash(b);
                    insert(a,b,w);
                    scanf("%c",&a[0]);
                    if(a[0]=='\n')
                        break;
                }
                while(scanf("%s",&b)==1)
                {
                    int w=ELFhash(b);
                    if(find(b,w)==0)
                    printf("eh\n");
                }
                return 0;
            }

            本文來自CSDN博客,轉(zhuǎn)載請標(biāo)明出處:http://blog.csdn.net/cugbliang/archive/2008/05/30/2497539.aspx

            posted on 2009-07-01 14:29 luis 閱讀(937) 評論(0)  編輯 收藏 引用 所屬分類: 轉(zhuǎn)載
            <2009年7月>
            2829301234
            567891011
            12131415161718
            19202122232425
            2627282930311
            2345678

            常用鏈接

            留言簿(3)

            隨筆分類

            隨筆檔案

            文章分類

            文章檔案

            友情鏈接

            搜索

            •  

            最新評論

            閱讀排行榜

            評論排行榜

            伊人久久大香线蕉av一区| 青青青青久久精品国产| 久久久久久精品成人免费图片| 色欲综合久久躁天天躁| 久久Av无码精品人妻系列| 精品国产热久久久福利| 少妇久久久久久被弄高潮| 久久精品成人免费观看97| 亚洲熟妇无码另类久久久| 久久久久女教师免费一区| 国产综合久久久久| 久久丫忘忧草产品| 久久久亚洲精品蜜桃臀| 成人妇女免费播放久久久| 久久久久久伊人高潮影院 | 99久久精品无码一区二区毛片| 亚洲а∨天堂久久精品| 一级做a爱片久久毛片| 伊人久久大香线焦AV综合影院| 国产亚洲色婷婷久久99精品91| WWW婷婷AV久久久影片| 午夜天堂精品久久久久| 午夜肉伦伦影院久久精品免费看国产一区二区三区| 久久午夜无码鲁丝片| 99久久综合国产精品免费| 欧美日韩中文字幕久久久不卡| 国产精品免费看久久久香蕉| 久久久精品午夜免费不卡| 国内精品人妻无码久久久影院 | 狠狠色婷婷综合天天久久丁香| 久久精品综合网| 久久久久久久女国产乱让韩| 人妻无码精品久久亚瑟影视| 亚洲精品乱码久久久久久不卡| 亚洲人AV永久一区二区三区久久| 久久人人爽人人爽人人片AV东京热| 伊人色综合久久| 色婷婷久久久SWAG精品| 久久亚洲高清综合| 久久人人爽人人爽人人片AV高清| 久久精品国产久精国产一老狼|