数据结构极客视频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