博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
Python hashmap
阅读量:4029 次
发布时间:2019-05-24

本文共 1235 字,大约阅读时间需要 4 分钟。

 

标签: 
 
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)  
你可能感兴趣的文章
S3C6410启动模式介绍
查看>>
Jlink + ADS调试 S3C2440
查看>>
2440初始化存储器原理(接上一篇)
查看>>
S3C2440 USB 设备控制器(转)
查看>>
Linux usb 设备驱动 (1)
查看>>
解决跨网场景下,CAS重定向无法登录的问题(无需修改现有代码)
查看>>
java反编译命令
查看>>
activemq依赖包获取
查看>>
概念区别
查看>>
关于静态块、静态属性、构造块、构造方法的执行顺序
查看>>
final 的作用
查看>>
在Idea中使用Eclipse编译器
查看>>
idea讲web项目部署到tomcat,热部署
查看>>
优化IDEA启动速度,快了好多。后面有什么优化点,会继续往里面添加
查看>>
JMeter 保持sessionId
查看>>
IDEA Properties中文unicode转码问题
查看>>
Idea下安装Lombok插件
查看>>
zookeeper
查看>>
Idea导入的工程看不到src等代码
查看>>
技术栈
查看>>