Python hashmap

 

pythonHashMap的一个实现 

标签: pythonhashmap
  533人阅读  评论(0)  收藏  举报
  分类:
 
  1. class LinearMap(object):  
  2.   
  3.     def __init__(self):  
  4.         self.items = []  
  5.   
  6.     def add(self, k, v):  
  7.         self.items.append((k, v))  
  8.   
  9.     def get(self, k):  
  10.         for key, val in self.items:  
  11.             if key == k:  
  12.                 return val  
  13.         raise KeyError  
  14.   
  15.   
  16. class BetterMap(object):  
  17.   
  18.     def __init__(self, n=100):  
  19.         self.maps = []  
  20.         for i in range(n):  
  21.             self.maps.append(LinearMap())  
  22.   
  23.     def find_map(self, k):  
  24.         index = hash(k) % len(self.maps)  
  25.         return self.maps[index]  
  26.   
  27.     def add(self, k, v):  
  28.         m = self.find_map(k)  
  29.         m.add(k, v)  
  30.   
  31.     def get(self, k):  
  32.         m = self.find_map(k)  
  33.         return m.get(k)  
  34.   
  35.   
  36. class <b style="color:#000;background:#66ffff">HashMap</b>(object):  
  37.     def __init__(self):  
  38.         self.maps = BetterMap(2)  
  39.         self.num = 0  
  40.   
  41.     def get(self, k):  
  42.         return self.maps.get(k)  
  43.   
  44.     def add(self, k, v):  
  45.         if self.num == len(self.maps.maps):  
  46.             self.resize()  
  47.   
  48.         self.maps.add(k, v)  
  49.         self.num += 1  
  50.   
  51.     def resize(self):  
  52.         new_map = BetterMap(self.num * 2)  
  53.   
  54.         for m in self.maps.maps:  
  55.             for k, v in m.items:  
  56.                 new_map.add(k, v)  
  57.   
  58.         self.maps = new_map  
  59.   
  60.   
  61. def main(script):  
  62.     import string  
  63.   
  64.     m = <b style="color:#000;background:#66ffff">HashMap</b>()  
  65.     s = string.ascii_lowercase  
  66.   
  67.     for k, v in enumerate(s):  
  68.         m.add(k, v)  
  69.   
  70.     for k in range(len(s)):  
  71.         print k, m.get(k)  
  72.   
  73.   
  74. if __name__ == '__main__':  
  75.     import sys  
  76.     main(*sys.argv)  
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值