zoukankan      html  css  js  c++  java
  • 用python实现哈希表

    哈哈,这是我第一篇博客园的博客。尝试了一下用python实现的哈希表,首先处理冲突的方法是开放地址法,冲突表达式为Hi=(H(key)+1)mod m,m为表长。

     1 #! /usr/bin/env python
     2 #coding=utf-8
     3 #实现哈希表(线性地址再散列)
     4 
     5 def ChangeKey(key, m, di):
     6     key01 = (key+di) % m
     7     return key01
     8 
     9 a = raw_input("Please entry the numbers:\n").split()
    10 m = len(a)
    11 dict01 = {}
    12 for i in a:
    13     key = int(i) % m
    14     if "%s" % key in dict01:
    15         NewKey = ChangeKey(key, m, 1)
    16         while "%s" % NewKey in dict01:         #因为下面的dict01的key值是以字符串来保存,因此这里作判断时也要用字符串格式
    17             NewKey = ChangeKey(NewKey, m, 1)
    18         dict01["%s" % NewKey] = int(i)
    19     else:
    20         dict01["%s" % key] = int(i)
    21 print dict01

    接下来是用开放地址法。

    目标,输入:key/value列表,输出:运用拉链法的哈希表

    对于下面的这个函数,输入的是一个这样的列表数据结构:["key01 val01", "key02 val01", "key03 val01", "key01 val02", "key02 val02", "key01 val03", ...]

    而函数返回一个这样的字典数据结构:{key01:[val01, val02, val03, ...],key02:[val01, val02...], key03:[val01, ...]}。这个函数和MapReduce思想中的Reduce功能是类似的。

    代码如下:

    def chainHash(InputList):
        res = {}
        for line in InputList:
            if line.split()[0] not in res:
                temp = []        #因为在拉链法中,键值包含多个对象,因此需要新建一个列表,把键值保存在这个列表中
                temp.append(line.split()[1])
                res["%s" % line.split()[0]] = temp
            else:
                res["%s" % line.split()[0]].append(line.split()[1])
        return res
    本文是原创内容,欢迎转载,但请注明出处! http://www.cnblogs.com/cjyfff/
  • 相关阅读:
    sun.misc.BASE64Encoder找不到的解决方法
    eclipse里大小写转化的快捷键是什么
    jface viewer 理解
    如何在遗留代码基础上开发
    谈谈技术文档的编写
    jre build path 中的限制问题导致一些代码无法编译..如果设置
    android update automatically ( android 自动升级)
    各大集群存储产品点评
    关于@Autowired 注释为何不需要get Set
    VRML之desk
  • 原文地址:https://www.cnblogs.com/cjyfff/p/3536525.html
Copyright © 2011-2022 走看看