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

posts - 195,  comments - 30,  trackbacks - 0

這是第一種哈希函數,運行時間短,但內存占用多。哈希函數是怎么得到的?我也想知道。。。
#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()函數,也沒體現出時間上的優(yōu)勢,但空間上確實是省了不少,可能是計算ELFhash()時浪費了時間吧,處理字符串哈希沖突的辦法目前只發(fā)現了線形探測法,雖然不理想,但愿將來能發(fā)現別的辦法。
ELFhash函數在UNIX系統V 版本4中的“可執(zhí)行鏈接格式”( Executable and Linking Format,即ELF )中會用到,ELF文件格式用于存儲可執(zhí)行文件與目標文件。ELFhash函數是對字符串的散列。它對于長字符串和短字符串都很有效,字符串中每個字符都 有同樣的作用,它巧妙地對字符的ASCII編碼值進行計算,ELFhash函數對于能夠比較均勻地把字符串分布在散列表中。
#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博客,轉載請標明出處:http://blog.csdn.net/cugbliang/archive/2008/05/30/2497539.aspx

posted on 2009-07-01 14:29 luis 閱讀(946) 評論(0)  編輯 收藏 引用 所屬分類: 轉載
<2012年12月>
2526272829301
2345678
9101112131415
16171819202122
23242526272829
303112345

常用鏈接

留言簿(3)

隨筆分類

隨筆檔案

文章分類

文章檔案

友情鏈接

搜索

  •  

最新評論

閱讀排行榜

評論排行榜

青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <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| 最新亚洲激情| 亚洲国产精品va在线观看黑人 | 久久久久免费视频| 久久综合一区二区三区| 欧美日韩亚洲视频| 国产日韩欧美综合一区| **欧美日韩vr在线| 亚洲深夜福利视频| 久久久久综合一区二区三区| 亚洲国产精品国自产拍av秋霞| 亚洲国产欧洲综合997久久| 在线综合欧美| 免费欧美网站| 国内精品久久久久影院色| av不卡在线| 欧美成人国产一区二区| 亚洲欧美一区二区三区极速播放| 久久久999| 国产精品福利片| 亚洲精品一区二区在线| 六月天综合网| 香蕉久久一区二区不卡无毒影院| 欧美jjzz| 激情婷婷亚洲| 久久精品国产欧美亚洲人人爽| 免费观看不卡av| 欧美亚洲视频在线观看| 国产精品久久久久久影视| 亚洲美女毛片| 欧美激情在线免费观看| 久久久91精品国产| 韩国一区二区在线观看| 久久大香伊蕉在人线观看热2| 亚洲国产精品成人| 久久综合免费视频影院| 狠狠狠色丁香婷婷综合激情| 欧美一区二区三区免费视| 亚洲视频精品在线| 国产精品久久二区二区| 亚洲欧美国产另类| 亚洲午夜在线| 国产精品外国| 久久国产精品久久精品国产 | 亚洲国产第一| 在线一区免费观看| 亚洲精品乱码| 欧美日韩亚洲高清一区二区| 亚洲美女啪啪| 日韩亚洲欧美在线观看| 欧美日韩国产一级片| 在线综合+亚洲+欧美中文字幕| 欧美成人小视频| 久久综合久久综合这里只有精品| 国产综合色在线| 久久久免费av| 久久人人爽人人爽爽久久| 亚洲高清一二三区| 亚洲国产精品久久久久婷婷884| 久久躁狠狠躁夜夜爽| 亚洲国产成人久久| 亚洲国产日韩欧美| 国产精品h在线观看| 欧美在线啊v| 久久久久在线观看| 99精品欧美一区二区三区| 夜夜精品视频一区二区| 国产欧美日韩另类视频免费观看 | 欧美性色aⅴ视频一区日韩精品| 亚洲国产日韩美| 亚洲欧洲一区二区在线观看 | 国产精品卡一卡二| 久久国产视频网站| 久久一二三区| 亚洲一区欧美一区| 久久国产精品久久久久久久久久| 伊人久久亚洲影院| 99精品久久免费看蜜臀剧情介绍| 国产精品久久午夜夜伦鲁鲁| 免费不卡在线观看| 欧美四级在线| 欧美不卡在线视频| 国产精品久久久| 欧美激情bt| 国产婷婷色一区二区三区在线| 毛片基地黄久久久久久天堂| 欧美日韩日日骚| 久久综合影音| 国产精品成人一区二区网站软件| 久久riav二区三区| 欧美日韩激情小视频| 老司机午夜免费精品视频| 欧美视频网址| 欧美激情一区二区三区蜜桃视频| 国产精品videossex久久发布| 久久婷婷蜜乳一本欲蜜臀| 欧美精品二区三区四区免费看视频| 亚洲永久视频| 欧美成年人视频网站欧美| 久久精品国产欧美激情| 国产精品久久久久77777| 亚洲啪啪91| 亚洲国产综合在线看不卡| 欧美在线你懂的| 亚洲六月丁香色婷婷综合久久| 久久九九久精品国产免费直播| 91久久精品视频| 午夜日韩激情| 欧美亚洲网站| 欧美香蕉大胸在线视频观看| 亚洲人成77777在线观看网| 亚洲二区三区四区| 久久久久久夜精品精品免费| 久久精品欧美日韩| 国产视频综合在线| 欧美一区午夜精品| 欧美在线精品免播放器视频| 欧美午夜欧美| 99热精品在线| 亚洲视频福利| 欧美深夜福利| 亚洲视频在线观看免费| 亚洲欧美999| 国产精品乱码人人做人人爱| 亚洲午夜精品久久| 亚洲欧美精品伊人久久| 国产精品国内视频| 亚洲欧美国产77777| 欧美在线999| 韩国亚洲精品| 欧美高潮视频| 99国产精品久久久久久久| 亚洲免费在线| 国产三级欧美三级| 久久久久久综合| 亚洲国产精品va在线看黑人 | 中日韩美女免费视频网址在线观看| 久久久一区二区三区| 免费日韩精品中文字幕视频在线| 国产又爽又黄的激情精品视频| 亚洲在线黄色| 久久久另类综合| 亚洲高清一二三区| 欧美日韩一区成人| 午夜精品久久久久久久久久久久| 亚洲欧美日韩在线综合| 国产亚洲免费的视频看| 久久久亚洲精品一区二区三区| 久久久人成影片一区二区三区观看| 国产一区视频网站| 欧美成人xxx| 亚洲天天影视| 欧美成人亚洲成人日韩成人| 一区二区三区四区五区在线| 国产伦一区二区三区色一情| 美女91精品| 亚洲午夜激情网页| 亚洲国产mv| 久久国产福利| 9色精品在线| 国产小视频国产精品| 欧美精品91| 欧美一级视频精品观看| 亚洲人被黑人高潮完整版| 欧美伊人久久| 99在线精品免费视频九九视| 国产一级精品aaaaa看| 欧美日韩免费精品| 久热爱精品视频线路一| 亚洲欧美日本另类| 亚洲精品欧洲精品| 老司机免费视频一区二区三区 | 在线观看国产精品淫| 亚洲男人第一网站| 欧美日韩综合| 久久久久综合网| 亚洲天堂男人| 亚洲精品欧美极品| 亚洲观看高清完整版在线观看| 亚洲欧美日本精品| 99精品国产在热久久婷婷| 好吊日精品视频| 国产嫩草影院久久久久| 欧美日韩一级大片网址|