广告
返回顶部
首页 > 资讯 > 后端开发 > Python >Python hashmap
  • 487
分享到

Python hashmap

Pythonhashmap 2023-01-31 04:01:47 487人浏览 独家记忆

Python 官方文档:入门教程 => 点击学习

摘要

  标签: pythonHashMap 2014-10-15 18:42 533人阅读 评论(0) 收藏 举报  分类:   Python(40)  版权声明:本文为博主原创文章,未经博主允许不得转载。 [

 
标签: pythonHashMap
2014-10-15 18:42 533人阅读 评论(0) 收藏 举报
 分类:
 
[python] view plain copy
 在CODE上查看代码片派生到我的代码片
  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)  

--结束END--

本文标题: Python hashmap

本文链接: https://www.lsjlt.com/news/187798.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • Python hashmap
      标签: pythonhashmap 2014-10-15 18:42 533人阅读 评论(0) 收藏 举报  分类:   Python(40)  版权声明:本文为博主原创文章,未经博主允许不得转载。 [...
    99+
    2023-01-31
    Python hashmap
  • Python Hashmap/Dicti
    Python 来自:http://www.dotnetperls.com/dictionary-python Built-in Dictionary List Set Tuple 2D Array Bytes Class Cons...
    99+
    2023-01-31
    Python Hashmap Dicti
  • python实现一个简易hashmap
    ...
    99+
    2023-01-31
    简易 python hashmap
  • python中HashMap的一个实现
    class LinearMap(object): def __init__(self): self.items = [] def add(self, k, v): self.items....
    99+
    2023-01-31
    python HashMap
  • HashMap详解
    一、HashMap集合简介 HashMap 基于哈希表的 Map 接口实现,是以 key-value 存储形式存在,即主要用来存放键值对。HashMap 的实现不是同步的,这意味着它不是线程安全的。...
    99+
    2023-09-22
    数据结构 java 链表
  • Java HashMap透析
    HashMap 是数组和链表组合组成的复杂结构,哈希值决定了键值在数组的位置,当哈希值相同时则以链表形式存储,当链表长度到达设定的阈值则会对其进行树化,这样做是为了保证数据安全和数据相关操作的效率HashMap 性能表现取决于哈希码的有效性...
    99+
    2021-08-10
    java教程 Java
  • 什么是HashMap
    什么是HashMap,很多新手对此不是很清楚,为了帮助大家解决这个难题,下面小编将为大家详细讲解,有这方面需求的人可以来学习下,希望你能有所收获。HashMap是一个非常重要的集合,日常使用也非常的频繁,同...
    99+
    2022-10-19
  • Java集合-HashMap
    目录概述重要的参数put函数的实现get函数的实现hash函数的实现RESIZE的实现概述 ①以数组+链表+红黑树实现。主要用来处理具有键值对特征的数据。②当链表长度大于阈值(或者红...
    99+
    2022-11-12
  • Java 中HashMap 详解
    本篇重点: HashMap的存储结构 HashMap的put和get操作过程 HashMap的扩容 关于transient关键字 HashMap的存储结构 HashMap 总体是数组+链表的存储结构, 从JDK1.8开始,当数组的长度大...
    99+
    2023-09-03
    哈希算法 散列表 java
  • HashMap实例分析
    这篇“HashMap实例分析”文章的知识点大部分人都不太理解,所以小编给大家总结了以下内容,内容详细,步骤清晰,具有一定的借鉴价值,希望大家阅读完这篇文章能有所收获,下面我们一起来看看这篇“HashMap实例分析”文章吧。场景扮演面试官: ...
    99+
    2023-06-27
  • 怎么理解HashMap
    这篇文章主要讲解了“怎么理解HashMap”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“怎么理解HashMap”吧!1、HashMap添加一个键值对的过程是怎么样的这是网上找的一张流程图,可...
    99+
    2023-06-16
  • HashMap的扩容机制
    目录 一、HashMap的底层 二、HashMap的扩容机制原理 1、JDK1.7版本扩容 2、JDK1.8版本扩容 三、HashMap底层JDK1.7到JDK1.8的变化 一、HashMap的底层 底层:采用数组+链表(JDK1.7)...
    99+
    2023-09-04
    java 面试 数据结构 链表 容器
  • javascript中有没有hashmap
    这篇文章主要介绍javascript中有没有hashmap,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完! javascript中有hashmap,其实现h...
    99+
    2022-10-19
  • Java中HashMap是什么
    这篇文章主要介绍Java中HashMap是什么,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!一、HashMap的结构图示本文主要说的是jdk1.8版本中的实现。而1.8中HashMap是数组+链表+红黑树实现的,大概...
    99+
    2023-06-15
  • HashMap和Hashtable的区别
    相同点: HashMap和Hashtable都是java.util包下的类HashMap和Hashtable都实现了Map接口,存储方式都是key-value形式HashMap和Hashtable同时...
    99+
    2023-09-01
    java 哈希算法 开发语言
  • java中hashmap怎么使用
    HashMap是Java中常用的数据结构之一,它是一个无序的键值对集合,可以存储不同类型的键和值。以下是HashMap的基本用法:1...
    99+
    2023-09-14
    java
  • Java HashMap源码是什么
    本篇内容主要讲解“Java HashMap源码是什么”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“Java HashMap源码是什么”吧!签名(signature)public cla...
    99+
    2023-06-17
  • HashMap底层原理分析
    小编给大家分享一下HashMap底层原理分析,希望大家阅读完这篇文章之后都有所收获,下面让我们一起去探讨吧!众所周知,HashMap是一个用于存储Key-Value键值对的集合,每一个键值对也叫做Entry。这些个键值对(Entry)分散存...
    99+
    2023-06-27
  • hashmap底层实现原理
    一、hashmap底层实现原理 HashMap是基于哈希表的Map接口的非同步实现。元素以键值对的形式存放,并且允许null键和null值,因为key值唯一(不能重复),因此,null键只有一个。另外,hashmap不保证元素存储的顺...
    99+
    2023-10-29
    底层 原理 hashmap
  • Java之HashMap案例详解
    概述 这篇文章,我们打算探索一下Java集合(Collections)框架中Map接口中HashMap的实现。Map虽然是Collctions框架的一部分,但是Map并没有实现Col...
    99+
    2022-11-12
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作