哈希


哈希表

根据key直接进行访问的无序数据结构,复杂度为O(1)

哈希表的实现---字典

初始化

d1 = dict()

查找
#使用中括号[]进行查找,括号内为特定的键, 键-值
dic = {"a": 1, "d":0, "e":3}
print(dic["a"]) #输出1
print(dic["z"]) #报错
修改
dic["a"] = 5
print(dic["a"]) #输出5
插入
dic["c"] = 4
#dic更新,字典中多了"c": 4
删除
#使用关键字del删除
del dic["a"]
print(dic["a"])
#dic更新,字典中少了"a": 5
补充

1、keys()方法

dic = {“a”:1, “d”:0, “e”:3}
print(list(dic.keys()))
#返回由键组成的一个列表
#输出["a", "d", "e"]

2、values()方法

print(list(dic.values()))
#输出[1, 0, 3]

3、items()方法

print(list(dic.items()))
#输出[{"a", 1}, {"d", 0}, {"e", 3}]

4、get()方法

dic = {“a”:1, “d”:0, “e”:3}
print(dic.get("a", 0))
#键a存在,输出对应值1
print(dic.get("z", 0))
#键z不存在,因此输出指定的值0
dic["a"] = dic.get("a", 0) + 1
#修改键值对{"a", 2}
dic["f"] = dic.get("f", 0) + 1
#修改键值对{"f", 1}

5、字典中键的特性

键必须不可变,并且可哈希的(字符串、数字、元组)

可变的数据类型不能作为字典的键(如列表、字典),是不可哈希的

字典的键必须各不相同

计数器类(counter)

​ 作用:特殊哈希表,直接统计变量中出现频率的次数

​ 代码示例

from collections import Counter
#引用库
#继承dict()所有方法,包括keys、value
#cnt统计字符串中所有字符的频率(键为字符,值为该字符出现的频率)
cnt = Counter("aabbcddd")
print(cnt)
#统计元组
cnt = Counter([1, 1, 3, 4, 2, 2, 1])
print(cnt)
#输出值列表
print(list(cnt.values()))

哈希集合


特点

无序集合

1、哈希集合存储不是键-值对,而是进存储数据的值;

2、哈希集合中的值各不相同;

3、哈希集合中的值必须是可哈希的,如列表不可以成为哈希集合中的值;

4、哈希集合是无序的。

初始化
#初始化一个空集合s1
s1 = set()
#初始化一个非空集合s2,集合无序,{}中的元素顺序不重要
s2 = {0, 1, 2, 3, 4}
s3 = set([0, 1, 2, 3, 4, ])
查找
#如果0存在于s中则输出true
if 0 in s:
print(True)
插入(add())与删除(remove())
s.add(5)  #s2 = {0, 1, 2, 3, 4, 5}
s.remove(3) #s2 = {0, 1, 2, 4}
列表与集合之间的转换

1、列表转换为集合

l1 = [1, 2, 2, 3, 4]
s1 = set(l1)
print(s1)
#输出s = {1, 2, 3, 4}

2、集合转换为列表

s2 = {1, 2, 3, 4}
l2 = list(s1)
print(l2)
#输出[1, 2, 3, 4]
比较哈希表和哈希集合
相同点

1、无序; 2、不重复; 3、可哈希的; 4、O(1)复杂度的查找

不同点

1、哈希表存储键- 值对,哈希集合仅存储值

2、哈希表中值可以是任意类型的数据,也可以重复,哈希集合是去重的

3、哈希表中的值可以修改,哈希集合中的值不能修改

哈希基础知识学习-python版的更多相关文章

  1. (转)Linux基础知识学习

    Linux基础知识学习 原文:http://blog.csdn.net/ye_wei_yang/article/details/52777499 一.Linux的磁盘分区及目录 Linux的配置是通过 ...

  2. Vue2基础知识学习

    Vue2基础知识学习 01.初识 new Vue({ el: '#root', //用于指定当前Vue实例为哪个容器服务,值通常为css选择器符 data () { return { } } }); ...

  3. GCC基础知识学习

    GCC基础知识学习 一.GCC编译选项解析 常用编译选项 命令格式:gcc [选项] [文件名] -E:仅执行编译预处理: -S:将C代码转换为汇编代码: -c:仅执行编译操作,不进行连接操作: -o ...

  4. 【Python教程】《零基础入门学习Python》(小甲鱼)

    [Python教程]<零基础入门学习Python>(小甲鱼) 讲解通俗易懂,诙谐. 哈哈哈. https://www.bilibili.com/video/av27789609

  5. 《零基础入门学习Python》【第一版】视频课后答案第001讲

    测试题答案: 0. Python 是什么类型的语言? Python是脚本语言 脚本语言(Scripting language)是电脑编程语言,因此也能让开发者藉以编写出让电脑听命行事的程序.以简单的方 ...

  6. 零基础入门学习Python(1)--我和Python的第一次亲密接触

    前言 最近在学习Python编程语言,于是乎就在网上找资源.其中小甲鱼<零基础入门学习Python>试听了几节课,感觉还挺不错,里面的视频都是免费下载,小甲鱼讲话也挺幽默风趣的,所以呢,就 ...

  7. Objective-c基础知识学习笔记

    Objective-c基础知识学习笔记(一) 一直有记录笔记的习惯.但非常久没分享一些东西了,正好上半年開始学习IOS了,如今有空写点.因开发须要,公司特意为我们配置了几台新MAC.还让我们自学了2周 ...

  8. 学习参考《零基础入门学习Python》电子书PDF+笔记+课后题及答案

    国内编写的关于python入门的书,初学者可以看看. 参考: <零基础入门学习Python>电子书PDF+笔记+课后题及答案 Python3入门必备; 小甲鱼手把手教授Python; 包含 ...

  9. 学习《零基础入门学习Python》电子书PDF+笔记+课后题及答案

    初学python入门建议学习<零基础入门学习Python>.适合新手入门,很简单很易懂.前一半将语法,后一半讲了实际的应用. Python3入门必备,小甲鱼手把手教授Python,包含电子 ...

  10. AXAJ基础知识学习

    AXAJ基础知识学习 博客首页 Ajax简介 ajxa全称是Asynchronous Javascript And XML ,就是异步的JS 和XML 通过Ajax可以再浏览器中向服务器发送异步请求, ...

随机推荐

  1. 如何去掉安装IDEA生成的鼠标右键

    IDEA去掉右键 在安装IDEA或其它Intellij软件时,因为整个安装流程都是英文的环境,有童鞋稍不注意,就会把Intellij系列软件自动生成鼠标右键给选上 但问题来了,Intellij系列软件 ...

  2. 图片预加载需要token认证的地址处理

    1.添加函数修改img的属性: /** * * @param {*} idName 传入的id,获取改img的dom,添加相应的数学 */ export const proxyImg = (idNam ...

  3. Flask web项目 gunicorn部署

    Flask web项目 gunicorn部署 安装pip3 install gunicorn 查看版本及是否安装成功flask --versiongunicorn -h ### 需要与app.py启动 ...

  4. PackageScanner

    package com.cmb.cox.utils;import com.alibaba.fastjson.JSON;import com.alibaba.fastjson.JSONObject;im ...

  5. 日志之log4j2和springboot

    log4j2比logback好用. 现在之所有以spring采用logback,根据我个人的理解应该是某种非常特殊的理由.否则log4j2的性能比logback更好,且异步性能极好! 异步日志是log ...

  6. VMware 17 Exception 0xc0000094 解决

    VMWare16的虚拟机升级到17时, 可能会出现虚拟机可以正常使用, 但编辑设置就会出现vmui错误的现像. VMware Workstation unrecoverable error: (vmu ...

  7. Linux设备模型:3、Uevent

    作者:wowo 发布于:2014-3-10 20:39 分类:统一设备模型 http://www.wowotech.net/device_model/uevent.html Uevent Uevent ...

  8. 张高兴的 MicroPython 入门指南:(一)环境配置、Blink、部署

    目录 什么是 MicroPython 环境配置 硬件部分 软件部分 Hello World! Blink Pico 的引脚 常见电子元件 面包板 跳线 开关 发光二极管 电阻 使你的 Pico 闪烁 ...

  9. 【韦东山】嵌入式全系统:单片机-linux-Android对硬件操作的不同侧重点

    我是韦东山,一直从事嵌入式Linux培训,最近打算连载一系列文章. 正在录制全新的嵌入式Linux视频,使用新路线,不再从裸机/uboot开始,效率更高. 对应文档也会写成书<<嵌入式Li ...

  10. 能说下 vue-router 中常用的 hash 和 history 路由模式实现原理吗?

    这个router有两种模式:hash模式(默认).history模式(需配置mode: 'history') 然后,我们来研究下两者的原理: 我们先来认识下这位朋友#,这个#就是hash符号,中文名哈 ...