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

隨筆-91  評論-137  文章-0  trackbacks-0
  1 #include <iostream>
  2 
  3 template <typename _Type>
  4 class HashTable
  5 {
  6 public:
  7     HashTable(int Length)
  8     {
  9         Element = new _Type[Length];
 10         for(int i=0;i<Length;i++)
 11             Element[i] = -1;
 12         this->Length = Length;
 13         Count = 0;
 14     }
 15     
 16     ~HashTable()
 17     {
 18         delete[] Element;
 19     }
 20     
 21     // Hash函數
 22     virtual int Hash(_Type Data)
 23     {
 24         return Data % Length;
 25     }
 26     
 27     // 再散列法
 28     virtual int ReHash(int Index,int Count)
 29     {
 30         return (Index + Count) % Length;
 31     }
 32     
 33     // 查找某個元素是否在表中
 34     virtual bool SerachHash(_Type Data,int& Index)
 35     {
 36         Index = Hash(Data);
 37         int Count = 0;
 38         while(Element[Index] != -1 && Element[Index] != Data)
 39             Index = ReHash(Index,++Count);
 40         return Data == Element[Index] ? true : false;
 41     }
 42     
 43     virtual int SerachHash(_Type Data)
 44     {
 45         int Index = 0;
 46         if(SerachHash(Data,Index)) return Index;
 47         else return -1;
 48     }
 49     
 50     // 插入元素
 51     bool InsertHash(_Type Data)
 52     {
 53         int Index = 0;
 54         if(Count < Length && !SerachHash(Data,Index))
 55         {
 56             Element[Index] = Data;
 57             Count++;
 58             return true;
 59         }
 60         return false;
 61     }
 62     
 63     // 設置Hash表長度
 64     void SetLength(int Length)
 65     {
 66         delete[] Element;
 67         Element = new _Type[Length];
 68         for(int i=0;i<Length;i++)
 69             Element[i] = -1;
 70         this->Length = Length;
 71     }
 72     
 73     // 刪除某個元素
 74     void Remove(_Type Data)
 75     {
 76         int Index = SerachHash(Data);
 77         if(Index != -1)
 78         {
 79             Element[Index] = -1;
 80             Count--;
 81         }
 82     }
 83     
 84     // 刪除所有元素
 85     void RemoveAll()
 86     {
 87         for(int i=0;i<Length;i++)
 88             Element[i] = -1;
 89         Count = 0;
 90     }
 91     
 92     void Print()
 93     {
 94         for(int i=0;i<Length;i++)
 95             printf("%d ",Element[i]);
 96         printf("\n");
 97     }
 98 protected:
 99     _Type* Element;        // Hash表
100     int Length;                // Hash表大小
101     int Count;                // Hash表當前大小
102 };
103 
104 void main()
105 {
106     HashTable<int> H(10);
107     printf("Hash Length(10) Test:\n");
108     int Array[6= {49,38,65,97,13,49};
109     for(int i=0;i<6;i++)
110         printf("%d\n",H.InsertHash(Array[i]));
111     H.Print();
112     printf("Find(97):%d\n",H.SerachHash(97));
113     printf("Find(49):%d\n",H.SerachHash(49));
114     H.RemoveAll();
115     H.SetLength(30);
116     printf("Hash Length(30) Test:\n");
117     for(int i=0;i<6;i++)
118         printf("%d\n",H.InsertHash(Array[i]));
119     H.Print();
120     printf("Find(97):%d\n",H.SerachHash(97));
121     printf("Find(49):%d\n",H.SerachHash(49));
122     system("pause");
123 }


運行結果:


由上圖可知給定的Hash表長度越長越不容易產生沖突,性能也就越高.

posted on 2010-08-10 23:37 lwch 閱讀(583) 評論(1)  編輯 收藏 引用 所屬分類: 數據結構

評論:
# re: 簡單的Hash表實現 2013-05-03 15:57 | tb
這個比較有用吧   回復  更多評論
  

只有注冊用戶登錄后才能發表評論。
網站導航: 博客園   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>
            夜夜嗨av一区二区三区| 亚洲欧美另类国产| 亚洲欧美激情在线视频| 一区二区电影免费在线观看| 欧美日韩精品欧美日韩精品一| 亚洲免费高清视频| 亚洲永久精品大片| 亚洲黄色成人久久久| 亚洲精品少妇| 国产在线欧美日韩| 黄色成人在线| 欧美激情第3页| 国产伦精品一区二区三区免费迷| 久久精品噜噜噜成人av农村| 久久久久久久一区| 亚洲一区二区三区在线视频| 欧美在线观看视频一区二区| 在线亚洲欧美视频| 欧美国产一区二区三区激情无套| 欧美在线免费视频| 欧美午夜片欧美片在线观看| 欧美大片免费观看| 国内精品模特av私拍在线观看| 一区二区激情| 亚洲一区二区精品| 欧美色区777第一页| 欧美高清在线一区| 亚洲欧美高清| 午夜性色一区二区三区免费视频| 欧美日本一区| 亚洲精选91| 一本色道久久综合亚洲精品不卡| 欧美~级网站不卡| 欧美成人在线免费观看| 亚洲电影专区| 欧美成人国产一区二区| 亚洲国产乱码最新视频| 亚洲国产精品999| 欧美国产日韩一二三区| 国产午夜精品麻豆| 久久久久综合网| 亚洲日本视频| 亚洲一区国产视频| 国内伊人久久久久久网站视频| 久久精品一级爱片| 欧美激情网友自拍| 亚洲综合日韩| 亚洲国产黄色| 国产日韩欧美精品综合| 欧美片网站免费| 久久精品国产视频| 一区二区日韩欧美| 国产精品久久久久一区二区三区| 久久综合给合| 在线亚洲美日韩| 亚洲国产精品成人综合色在线婷婷 | 亚洲视屏一区| 国产亚洲欧美一区在线观看| 久久免费的精品国产v∧| 一本久久综合亚洲鲁鲁| 欧美成人午夜剧场免费观看| 欧美一级播放| 亚洲一区视频在线| 另类酷文…触手系列精品集v1小说| 一本不卡影院| 1024亚洲| 国产伊人精品| 国产欧美日韩伦理| 国产精品免费久久久久久| 欧美色另类天堂2015| 欧美成人自拍视频| 麻豆亚洲精品| 欧美精品久久久久久久免费观看| 久久久久久久一区二区| 久久亚洲捆绑美女| 久久夜色精品国产噜噜av| 久久久91精品国产一区二区三区| 亚洲欧美日韩直播| 久久久av毛片精品| 久久综合中文| 欧美午夜剧场| 精品51国产黑色丝袜高跟鞋| 国产综合香蕉五月婷在线| 国产综合久久久久影院| 亚洲国产精品99久久久久久久久| 亚洲国产成人不卡| 亚洲天堂免费观看| 久久av一区二区| 亚洲福利在线看| 亚洲小说欧美另类社区| 午夜亚洲福利在线老司机| 狼人社综合社区| 国产精品伦子伦免费视频| 在线看片欧美| 久久视频国产精品免费视频在线 | 欧美国产91| 欧美一区二区三区久久精品茉莉花| 久久久久九九视频| 国产亚洲精品自拍| 亚洲欧美春色| 一区二区国产日产| 欧美日韩综合视频| 日韩一级裸体免费视频| 亚洲二区在线视频| 亚洲曰本av电影| 亚洲国产精品热久久| 久久久精品动漫| 国产午夜亚洲精品羞羞网站| 亚洲一区二区在线免费观看视频| 亚洲国产网站| 欧美久久久久久蜜桃| 亚洲欧洲一区二区天堂久久 | 亚洲视频视频在线| 亚洲国产毛片完整版| 老司机一区二区| 在线观看亚洲一区| 美女视频黄 久久| 久久久久天天天天| 一区二区三区在线高清| 欧美国产日韩a欧美在线观看| 久久精品女人| 夜夜嗨av色综合久久久综合网| 亚洲精品日韩精品| 国产精品日本精品| 午夜精品美女自拍福到在线| 欧美一级视频| 日韩亚洲精品电影| 亚洲午夜精品久久| 一区二区久久久久| 黄色资源网久久资源365| 欧美高清成人| 国产精品久久久久9999吃药| 久久精品人人做人人爽| 免费在线成人| 久久免费视频观看| 欧美极品aⅴ影院| 久久久另类综合| 国产精品国产三级国产aⅴ9色| 久久久久久久999| 欧美日韩在线播放一区二区| 久久综合狠狠| 国产亚洲欧美日韩美女| 亚洲欧洲免费视频| 在线免费精品视频| 久久狠狠亚洲综合| 亚洲免费影视| 亚洲精品黄色| 一区二区三区在线视频免费观看| 91久久亚洲| 一区二区三区欧美在线观看| 久久天堂精品| 欧美不卡在线| 激情亚洲网站| 久久视频免费观看| 欧美激情精品久久久久久久变态| 韩国v欧美v日本v亚洲v| 午夜精彩视频在线观看不卡| 亚洲一区二区伦理| 欧美日韩在线高清| 亚洲性xxxx| 久久精品91久久香蕉加勒比 | 黑人巨大精品欧美黑白配亚洲| 99热免费精品| 久久精品国产99国产精品澳门| 国产日韩欧美成人| 久久九九久精品国产免费直播| 久久亚洲精品一区二区| 在线观看亚洲精品视频| 欧美大片免费| 亚洲综合三区| 欧美韩日一区二区| 午夜精品影院在线观看| 国内精品伊人久久久久av影院| 久久夜色精品| 亚洲欧美欧美一区二区三区| 久久综合久色欧美综合狠狠 | 国产免费成人| 久久在线免费观看| 亚洲图片你懂的| 欧美电影免费观看大全| 亚洲欧美精品在线| 亚洲电影中文字幕| 国产婷婷色综合av蜜臀av| 欧美第十八页| 久久免费国产精品| 欧美尤物一区| 日韩一区二区福利| 亚洲国产日韩一区二区| 欧美大尺度在线| 麻豆成人在线观看| 久久永久免费| 免费亚洲一区| 伊人精品在线| 亚洲人成网站777色婷婷| 国产在线播精品第三| 夜夜嗨av一区二区三区中文字幕 | 久久九九热免费视频| 性色av香蕉一区二区| 亚洲欧美日韩国产综合精品二区| 一区二区毛片|