数据结构极客视频2

1.哈希表

概念

哈希表如下图:通过一个哈希函数得到一个存储位置 如果需要查找一个元素 若遍历时间复杂度是N 若用哈希O(1)注意使用哈希表存储的元素是没有大小关系的
在这里插入图片描述

哈希冲突

当通过哈希函数 映射的位置已经存在元素的时候遍产生了冲突 解决方式有多种 下图是一种 在后面加个链表
在这里插入图片描述

list Map Set

list 可以存放重复元素的链表
Map 像个字典
Set 不能存放重复元素
HashMap,HashSet用哈希表 TreeMap,TreeSet用的是二叉树
HashMap 查询的时间复杂度是 1 HashTree的查询时间复杂度是logN 但是是乱序的 但是HashTree是相对有序的
常用语言的结果 python没有treemap
在这里插入图片描述

题目:Anagram

在这里插入图片描述
问题描述 给定两个单词 判断是否由相同数量相同字母构成的
解题思路 1.对两个字符串按着字典序排序 使用快排 对于N个元素 复杂度是NlogN 然后再对比
2.使用Map 让每一个字母都进map 复杂度是N 对于Map的插入 是O(1) 所以最后O(N)

代码:

  • 解法1代码
def isAnagram1(self,s,t):
    return sorted(s)==sorted(t)
  • 解法2代码
##使用map
def isAnagram2(self,s,t):
    dic1,dic2 ={
   },{
   }
    for item in s
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值