哈希基础知识学习-python版
哈希
哈希表
根据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版的更多相关文章
- (转)Linux基础知识学习
Linux基础知识学习 原文:http://blog.csdn.net/ye_wei_yang/article/details/52777499 一.Linux的磁盘分区及目录 Linux的配置是通过 ...
- Vue2基础知识学习
Vue2基础知识学习 01.初识 new Vue({ el: '#root', //用于指定当前Vue实例为哪个容器服务,值通常为css选择器符 data () { return { } } }); ...
- GCC基础知识学习
GCC基础知识学习 一.GCC编译选项解析 常用编译选项 命令格式:gcc [选项] [文件名] -E:仅执行编译预处理: -S:将C代码转换为汇编代码: -c:仅执行编译操作,不进行连接操作: -o ...
- 【Python教程】《零基础入门学习Python》(小甲鱼)
[Python教程]<零基础入门学习Python>(小甲鱼) 讲解通俗易懂,诙谐. 哈哈哈. https://www.bilibili.com/video/av27789609
- 《零基础入门学习Python》【第一版】视频课后答案第001讲
测试题答案: 0. Python 是什么类型的语言? Python是脚本语言 脚本语言(Scripting language)是电脑编程语言,因此也能让开发者藉以编写出让电脑听命行事的程序.以简单的方 ...
- 零基础入门学习Python(1)--我和Python的第一次亲密接触
前言 最近在学习Python编程语言,于是乎就在网上找资源.其中小甲鱼<零基础入门学习Python>试听了几节课,感觉还挺不错,里面的视频都是免费下载,小甲鱼讲话也挺幽默风趣的,所以呢,就 ...
- Objective-c基础知识学习笔记
Objective-c基础知识学习笔记(一) 一直有记录笔记的习惯.但非常久没分享一些东西了,正好上半年開始学习IOS了,如今有空写点.因开发须要,公司特意为我们配置了几台新MAC.还让我们自学了2周 ...
- 学习参考《零基础入门学习Python》电子书PDF+笔记+课后题及答案
国内编写的关于python入门的书,初学者可以看看. 参考: <零基础入门学习Python>电子书PDF+笔记+课后题及答案 Python3入门必备; 小甲鱼手把手教授Python; 包含 ...
- 学习《零基础入门学习Python》电子书PDF+笔记+课后题及答案
初学python入门建议学习<零基础入门学习Python>.适合新手入门,很简单很易懂.前一半将语法,后一半讲了实际的应用. Python3入门必备,小甲鱼手把手教授Python,包含电子 ...
- AXAJ基础知识学习
AXAJ基础知识学习 博客首页 Ajax简介 ajxa全称是Asynchronous Javascript And XML ,就是异步的JS 和XML 通过Ajax可以再浏览器中向服务器发送异步请求, ...
随机推荐
- rabbitMq消息接收转换对象,Json解析字符串报错syntax error, expect {, actual string, pos 0, fastjson-version 1.2.62解决
Expected BEGIN_OBJECT but was STRING at line 1 column 2 path $ syntax error, expect {, actual string ...
- 判断日期是否为周六周日,BigDecimal比较大小
判断日期是否为周六周日,BigDecimal比较大小 package com.example.core.mydemo.date; import java.math.BigDecimal; import ...
- 【踩坑】.NET 8.0 自定义IExceptionHandler不生效
中间件实现异常处理 在ASP.NET Core里,我们可以使用中间件(Middleware)实现全局的异常处理. 如内置的异常处理中间件 UseExceptionHandler app.UseExce ...
- python 将查询到数据,处理成包含列名和数据的字典类型数据
try: self.connect_dbserver() self.cursor.execute(sql) res = self.cursor.fetchall() # 返回的是数组的类型 print ...
- SPI 协议学习
SPI 协议学习 背景 2年之前学过SPI,但是因为现在太久没用.基础知识不牢靠(对自己的面试表现不满意):所以重新整理了一遍. SPI接口的一个缺点:没有指定的流控制,没有应答机制确认是否接收到数据 ...
- url编码方式
url编码在线工具: http://tool.chinaz.com/tools/urlencode.aspx url编码:风景->%e9%a3%8e%e6%99%af 附HTTP请求过程: ht ...
- 配置hive环境步骤(zookeeper高可用集群已搭建)
安装mysql:1. 检查当前环境是否安装mysql服务(命令:rpm -qa | grep -i mysql)2. 卸载自带的mysql3. 卸载软件:rpm -e --nodeps mysql-l ...
- Spring Reactor基本介绍和案例
1. Reactor 对比 1.1 Reactor 线程模型 Reactor 线程模型就是通过 单个线程 使用 Java NIO 包中的 Selector 的 select()方法,进行监听.当获取到 ...
- python subprocess读取终端输出内容
参考链接:https://www.cnblogs.com/songzhenhua/p/9312718.html https://www.cnblogs.com/darkchii/p/9013673.h ...
- 典型性相关分析在SPSS中的实现
典型性相关分析是研究两组变量(每组变量中都可能有多个指标)之间相关关系的一种多元统计方法.它能够揭示出两组变量之间的内在联系. 本文着重模型在spss中的应用,通过一道例题解释各个指标的意义.详细推导 ...