首页 > 其他 > 详细

哈希表原理及hashmap简单实现

时间:2015-07-21 23:34:57      阅读:295      评论:0      收藏:0      [点我收藏+]

原理留待。

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

简单hashmap类定义:

 1 #include<iostream>
 2 using namespace std;
 3 class MySimpleHashmap
 4 {
 5 public:
 6     int *Array;
 7     enum{MaxHashSize=7};
 8 
 9     int hashcode(int &key);
10 
11 public:
12     MySimpleHashmap();
13     ~MySimpleHashmap();
14 
15     int& operator[](int & key);
16 
17 };
18 
19 
20 int& MySimpleHashmap::operator [](int& key)
21 {
22     return Array[hashcode(key)];
23 }
24 
25 
26 MySimpleHashmap::MySimpleHashmap()
27 {
28     Array=new int[MaxHashSize];
29     
30     for(int i=0;i<MaxHashSize;i++)
31     {
32         Array[i]=0;
33     }
34 }
35 
36 MySimpleHashmap::~MySimpleHashmap()
37 {
38     delete[] Array;
39     Array=NULL;
40 }
41 
42 int MySimpleHashmap::hashcode(int& key)
43 {
44     while(true)
45     {
46         if(Array[key%MaxHashSize]==0)
47         {
48             return key%MaxHashSize;
49         }
50         else
51         {
52             key++;
53         }
54     }
55 }

main.c

 

 1 #include "VpoetHashmap.h"
 2 #include <iostream>
 3 using namespace std;
 4 
 5 int main()
 6 {
 7     MySimpleHashmap MyHash;
 8     
 9     int key1=15; //hashkey=1
10     int key2=16;  //hashkey=2
11     int key3=9;  //hashkey=2
12     int key4=11;   //hashkey=4冲突
13     int key5=5;    //hashkey=5
14 
15     MyHash[key1]=100;
16     MyHash[key2]=200;
17     MyHash[key3]=300;
18     MyHash[key4]=400;
19     MyHash[key5]=500;
20 
21     cout<<"hash table node1:"<<MyHash.Array[0]<<endl;
22     cout<<"hash table node2:"<<MyHash.Array[1]<<endl;
23     cout<<"hash table node3:"<<MyHash.Array[2]<<endl;
24     cout<<"hash table node4:"<<MyHash.Array[3]<<endl;
25     cout<<"hash table node5:"<<MyHash.Array[4]<<endl;
26     cout<<"hash table node6:"<<MyHash.Array[5]<<endl;
27     cout<<"hash table node7:"<<MyHash.Array[6]<<endl;
28     return 0;
29 }

 

运行截图:

技术分享

哈希表原理及hashmap简单实现

原文:http://www.cnblogs.com/vpoet/p/4665791.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!