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

step by step

 

散列2

3 不使用鏈表的散列表
    分離鏈接散列算法的缺點是使用一些鏈表。由于給新單元分配地址需要時間,因此這就導致算法的速度有些緩慢,同時算法實際上還要求第二種數據結構的實現。解決沖突的另一個方法是當沖突發生時就嘗試選擇另一個單元,直到找到空的單元。更正式地,單元hi(x)=(hash(x)+f(i))mod TableSize,且f(0)=0.函數f是沖突解決函數。因為所有的數據都要置入表內,所以使用這個方案所需要的表要比分離鏈接散列需要的表大。一般說來,對不使用分離鏈接法的散列表來說,其裝填因子應該低于λ=0.5。我們稱這樣的表為探測散列表(probing hash tables)。
    (1)當f是i的線性函數時,為線性探測,一般情況下f(i)=i,線性探測容易在占據的單元形成一些區塊,其結果成為一次聚集(primary clustering)。
    (2)平方探測是消除線性探測中一次聚集問題的沖突解決方法。平方探測就是沖突函數為二次函數的探測方法。流行的選擇是f(i)=i2.
               定理:如果使用平方探測,且表的大小是素數,那么當表至少有一半是空的時候,總能夠插入一個新的元素。
        如果哪怕表有比一半多一個的位置被填滿,那么插入都有可能失敗(雖然這種可能性極小)。另外,表的大小是素數也非常重要。如果表的大小不是素數,則備選單元
        的個數可能會銳減。例如,若表的大小是16,那么備選單元只能在距散列值1,4或9遠處。
        在探測散列表中標準的刪除操作不能執行,因為相應的單元可能已經引起過沖突,元素繞過它存儲在別處。因此,探測散列表需要懶惰刪除。
        實現探測散列表所需要的類接口在下圖中給出。這里不使用鏈表數組,而是使用散列表項單元數組。嵌套的類HashEntry存儲在info成員中一個項的狀態,這個狀態可
        以是ACTIVE,EMPTY或DELETED。

   

 1//使用探測策略的散列表的類接口,包括嵌套的HashEntry
 2  類
 3template <typename HashedObj>
 4class HashTable
 5{
 6public:
 7    explicit HashTable( int size = 101 );
 8    
 9    bool contains( const HashedObj &x ) const;
10    
11    void makeEmpty();
12    bool insert( const HashedObj &x );
13    bool remove( const HashedObj &x );
14    
15    emum EntryType (ACTIVE,EMPTY,DELETED );
16
17private:
18    struct HashEntry
19    {
20        HashedObj element;
21        EntryType info;
22        HashEntry( const HashedObj & e = HashedObj(), EntryType i = EMPTY ) : element(e), info(i) { }
23    }
;
24
25    vector<HashEntry> array;
26    int currentSize;
27 
28    bool isActive( int currentPos ) const;
29    int findPos( const HashedObj &x ) const;
30    void rehash();
31    int myhash( const HashedObj &x ) const;
32}
;


 

 1//初始化平方探測散列表的例程
 2explicit HashTable( int size = 101 ) : array(nextPrime( size ) )
 3{ makeEmpty(); }
 4
 5void makeEmpty()
 6{
 7    currentSize = 0;
 8    forint i = 0; i<array.size(); i++ )
 9        array[i].info = EMPTY;
10}



 

 1//使用平方探測進行散列的contains例程
 2bool contains( const HashedObj &x ) const
 3{
 4    return isActive( findPos(x) ); }

 5
 6int findPos( const HashedObj &x ) const
 7{
 8    int offset = 1;
 9    int currentPos = myhash(x);
10    
11    //下面是一個小小的trick
12    while ( array[ currentPos ].info != EMPTY && array[ currentPos ].element != x )
13    {
14        currentPos += offset;
15        offset += 2;
16        if( currentPos >= array.size() )
17        currentPos -= array.size();
18    }

19    
20    return currentPos;
21}

22
23bool isActive( int currentPos ) const
24{
25    return array[ currentPos ].info == ACTIVE; }



 

 1//使用平方探測的散列表的insert和remove例程
 2bool insert ( const HashedObj &x )
 3{
 4    int currentPos = findPos( x );
 5    if ( isActive ( currentPos ) )
 6        return false;
 7    
 8    array[ currentPos ] = hashEntry( x, ACTIVE );
 9    if++currentSize > array.size() / 2 )
10        rehash();
11    
12    return true;
13}

14
15bool remove( const HashedObj &x )
16{
17    int currentPos = findPos(x);
18    if ( !isActive( currentPos ) )
19        return false;
20    
21    array[ currentPos ].info = DELETED;//傳說中的懶惰刪除
22    return true;
23}


  (3)最后一個沖突解決方法是雙散列(double hashing)。對于雙散列,一種流行的選擇是f(i)=i*hash2(x)。這個公式是說,將第二個散列函數應用到x并在距離hash2(x),2hash2(x),
      ...等處探測。hash2(x)選擇不好將會非常糟糕。
   
.

posted on 2009-11-26 20:20 小羅羅 閱讀(499) 評論(0)  編輯 收藏 引用


只有注冊用戶登錄后才能發表評論。
網站導航: 博客園   IT新聞   BlogJava   博問   Chat2DB   管理


導航

統計

常用鏈接

留言簿

隨筆檔案

搜索

最新評論

閱讀排行榜

評論排行榜

青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <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>
            香蕉av777xxx色综合一区| 香蕉成人伊视频在线观看| 国产精品porn| 欧美大片免费久久精品三p| 久色成人在线| 欧美搞黄网站| 欧美日韩国产一区二区| 欧美精品久久久久a| 欧美日韩亚洲一区二区三区在线观看| 欧美电影免费观看大全| 欧美三级网页| 国产亚洲免费的视频看| 在线观看av不卡| 日韩亚洲欧美高清| 亚洲欧美激情四射在线日 | 9久re热视频在线精品| 亚洲免费观看高清在线观看| 一本久久综合亚洲鲁鲁五月天| 夜夜嗨av色综合久久久综合网| 在线亚洲一区二区| 欧美自拍偷拍午夜视频| 欧美国产精品人人做人人爱| 欧美激情一区二区三区蜜桃视频| 亚洲黄网站黄| 99国产精品久久久久久久久久 | 影音先锋久久久| 亚洲国产精品成人| 亚洲影院一区| 免费成人在线观看视频| 一区二区三区.www| 久久久综合精品| 国产精品国产三级国产aⅴ浪潮 | 你懂的国产精品| 国产精品视频1区| 亚洲第一伊人| 小黄鸭视频精品导航| 欧美激情一区二区三区蜜桃视频 | 黄色成人在线网址| 亚洲视频免费在线| 欧美成人午夜影院| 性欧美xxxx视频在线观看| 欧美国产日韩一区二区| 国产自产女人91一区在线观看| 国产精品99久久久久久宅男 | 久久人人九九| 一区二区三区精品视频| 蜜臀久久久99精品久久久久久 | 久久综合九色九九| 国产精品日韩精品欧美在线| 亚洲免费大片| 欧美 日韩 国产精品免费观看| 亚洲天堂免费观看| 欧美精品在线免费| 亚洲国产清纯| 欧美.www| 久久先锋资源| 国内精品视频久久| 欧美中文在线字幕| 亚洲欧美日韩一区二区三区在线观看| 日韩视频免费在线观看| 免费成人网www| 在线观看亚洲| 麻豆9191精品国产| 久久精品99国产精品日本| 国产亚洲精品自拍| 久久久久九九视频| 欧美中文字幕久久| 国语自产精品视频在线看| 久久精选视频| 久久不射2019中文字幕| 黄色小说综合网站| 老色鬼久久亚洲一区二区| 久久亚洲精品伦理| 亚洲青涩在线| 亚洲精品孕妇| 国产精品初高中精品久久| 午夜精品福利一区二区三区av| 亚洲深夜福利| 国产一区二区在线免费观看| 另类av导航| 欧美成人自拍| 亚洲一区二区久久| 先锋影音国产一区| 亚洲第一中文字幕在线观看| 亚洲国产你懂的| 欧美日本国产视频| 午夜精品久久久久影视| 欧美自拍丝袜亚洲| 亚洲日韩第九十九页| 日韩视频不卡| 精品1区2区3区4区| 日韩天堂在线视频| 国内精品久久久久国产盗摄免费观看完整版| 久久久噜久噜久久综合| 欧美成人激情在线| 亚洲综合精品一区二区| 久久精品国产99国产精品澳门| 亚洲精品免费一二三区| 亚洲午夜久久久久久久久电影院 | 欧美综合77777色婷婷| 久久久在线视频| 亚洲免费在线电影| 久久久久综合网| 制服丝袜亚洲播放| 久久精品国产视频| 一区二区三区你懂的| 欧美一区免费视频| 一区二区三区蜜桃网| 久久成人资源| 亚洲一区二区综合| 久久一区免费| 久久疯狂做爰流白浆xx| 欧美日韩高清在线一区| 久热re这里精品视频在线6| 欧美日韩精品二区| 免费高清在线视频一区·| 国产精品激情| 亚洲女女女同性video| 久久久九九九九| 亚洲欧美日韩直播| 欧美伦理一区二区| 蜜桃伊人久久| 国产一区二区毛片| 亚洲视频在线播放| 一区二区欧美在线| 欧美成在线视频| 免费日韩精品中文字幕视频在线| 国产精品日本| 亚洲一级黄色片| 亚洲午夜视频在线| 欧美全黄视频| 亚洲黄色一区二区三区| 亚洲风情在线资源站| 午夜日韩激情| 性娇小13――14欧美| 国产精品久久久久9999吃药| 亚洲人成在线观看网站高清| 亚洲国产高清一区| 久热精品视频在线观看一区| 久久久亚洲精品一区二区三区 | 99re亚洲国产精品| 亚洲深夜影院| 欧美午夜片欧美片在线观看| 亚洲毛片在线观看| 亚洲一区二区三区乱码aⅴ蜜桃女| 欧美不卡三区| 欧美成人午夜77777| 亚洲国产美女精品久久久久∴| 久久久爽爽爽美女图片| 久久综合影视| 亚洲激情婷婷| 欧美精品一区二区三区很污很色的 | 亚洲第一页在线| 欧美成人免费在线视频| 亚洲第一网站| 亚洲视频图片小说| 国产精品五区| 久久久久国产精品一区二区| 老司机午夜精品视频| 亚洲国产成人久久综合一区| 欧美精品久久一区二区| 亚洲色图在线视频| 久久蜜桃资源一区二区老牛 | 日韩一区二区精品葵司在线| 亚洲性av在线| 国产亚洲一区在线| 久久尤物电影视频在线观看| 亚洲黄一区二区| 午夜精品久久久久久久99水蜜桃| 国产色视频一区| 另类图片综合电影| 99pao成人国产永久免费视频| 欧美一区二区三区在线观看| 一区二区在线看| 欧美日韩国产一区二区三区| 午夜在线视频观看日韩17c| 亚洲承认在线| 欧美自拍偷拍| 欧美日韩国产美| 香蕉免费一区二区三区在线观看| 久久精品首页| 一本久久精品一区二区| 国产午夜精品视频| 欧美精品久久久久久久| 久久av一区二区| 一区二区三区欧美| 欧美成人黄色小视频| 亚洲欧美在线x视频| 亚洲日韩视频| 国产综合香蕉五月婷在线| 欧美国产日韩一区二区在线观看| 亚洲欧美日韩国产中文| 最新亚洲激情| 米奇777超碰欧美日韩亚洲| 亚洲欧美国产视频| 亚洲剧情一区二区| 韩国一区电影| 国产精品亚洲激情| 欧美日韩调教| 欧美国产亚洲精品久久久8v|