hashtable&hash_set

Posted zijidan

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了hashtable&hash_set相关的知识,希望对你有一定的参考价值。

1.hashtable

技术图片

 

 

 1 class Node:
 2     def __init__(self,key,val):
 3         self.pair=(key,val)
 4         self.next=None      # next仍指向一个Node
 5 
 6 class MyHashMap(object):
 7 
 8     def __init__(self):
 9         self.table_len=1000
10         self.hash=[None]*self.table_len
11 
12     def put(self, key, value):
13         """
14         value will always be non-negative.
15         :type key: int
16         :type value: int
17         :rtype: None
18         """
19         idx=key%self.table_len
20         if(self.hash[idx]==None):
21             self.hash[idx]=Node(key,value)
22         else:
23             cur=self.hash[idx]
24             while True:
25                 if(cur.pair[0]==key):
26                     cur.pair=(key,value)
27                     return
28                 if cur.next==None:
29                     break
30                 cur=cur.next
31             cur.next=Node(key,value)   
32         
33 
34     def get(self, key):
35         """
36         Returns the value to which the specified key is mapped, or -1 if this map contains no mapping for the key
37         :type key: int
38         :rtype: int
39         """
40         idx=key%self.table_len
41         cur=self.hash[idx]
42         while(cur):
43             if(cur.pair[0]==key):
44                 return cur.pair[1]
45             else:
46                 cur=cur.next
47         return -1
48 
49 
50     def remove(self, key):
51         """
52         Removes the mapping of the specified value key if this map contains a mapping for the key
53         :type key: int
54         :rtype: None
55         """
56         idx=key%self.table_len
57         cur=self.hash[idx]
58         pre=self.hash[idx]
59 
60         if(cur==None):
61             return
62         
63         if(cur.pair[0]==key):
64             self.hash[idx]=cur.next
65         else:
66             cur=cur.next
67             while(cur):
68                 if(cur.pair[0]==key):
69                     pre.next=cur.next
70                     break
71                 else:
72                     pre=pre.next
73                     cur=cur.next
74         
75 
76         
77 
78 
79 # Your MyHashMap object will be instantiated and called as such:
80 # obj = MyHashMap()
81 # obj.put(key,value)
82 # param_2 = obj.get(key)
83 # obj.remove(key)

 

 

2.hashset

 

 1 class Node:
 2     def __init__(self,key):
 3         self.key=key
 4         self.next=None
 5 
 6 class MyHashSet(object):
 7 
 8     def __init__(self):
 9         """
10         Initialize your data structure here.
11         """
12         self.table_len=1000
13         self.hash_set=[None]*self.table_len
14 
15     def add(self, key):
16         """
17         :type key: int
18         :rtype: None
19         """
20         idx=key%self.table_len
21         cur=self.hash_set[idx]
22         if(cur==None):
23             self.hash_set[idx]=Node(key)
24         else:
25             while True:
26                 if(cur.key==key):
27                     return
28                 else:
29                     if(cur.next==None):
30                         break
31                         
32                 cur=cur.next
33 
34             cur.next=Node(key)
35         
36 
37     def remove(self, key):
38         """
39         :type key: int
40         :rtype: None
41         """
42         idx=key%self.table_len
43         cur=self.hash_set[idx]
44         pre=self.hash_set[idx]
45         if(cur==None):
46             return
47 
48         if(cur.key==key):
49             self.hash_set[idx]=cur.next
50         else:
51             cur=cur.next
52             while(cur):
53                 if(cur.key==key):
54                     pre.next=cur.next
55                     break
56                 else:
57                     pre=pre.next
58                     cur=cur.next 
59         
60 
61     def contains(self, key):
62         """
63         Returns true if this set contains the specified element
64         :type key: int
65         :rtype: bool
66         """
67         idx=key%self.table_len
68         cur=self.hash_set[idx]
69         if(cur==None):
70             return False
71         else:
72             while(cur):
73                 if(cur.key==key):
74                     return True
75                 else:
76                     cur=cur.next
77         return False
78 
79 
80 # Your MyHashSet object will be instantiated and called as such:
81 # obj = MyHashSet()
82 # obj.add(key)
83 # obj.remove(key)
84 # param_3 = obj.contains(key)

 

以上是关于hashtable&hash_set的主要内容,如果未能解决你的问题,请参考以下文章

STL系列之六 set与hash set

海量数据面试题----分而治之/hash映射 + hash统计 + 堆/快速/归并排序

14.hash_set

hash_set和hash_map

我可以使用成员变量作为 hash_set/hash_map 的键吗?

STL标准库 & 范型编程学习笔记(10):hashtable深度探索