代码随想录算法训练营二刷第18天 | 哈希表——数组和部分set

本文讨论了如何使用哈希表(数组和set,特别是unordered_set)解决字母异位词、赎金信问题以及求两个数组交集的问题,强调了数组和哈希表在不同场景下的适用性和空间效率。
摘要由CSDN通过智能技术生成

数组作为哈希表

242.有效的字母异位词

字母异位词就是字符串中字母出现的次数相同。即:一个字符串中出现的所有的字符是否在另一个字符串中重复出现了!反过来也要对应找到,因此要用哈希表!

数组就是简单的哈希表,但是数组的大小是受限的!这道题目只包含小写字母,那么使用数组来做哈希最合适不过。

383.赎金信

与上一题相似,要找的就是一个字符串中的所有字符能否在另一个字符串中找到,也就是:一个字符串中的元素是否在另一个字符串中重复出现,因此必要用到哈希表!

这道题中同样要求只有小写字母,那么就给我们浓浓的暗示,用数组!本题和242.有效的字母异位词 (opens new window)很像,242.有效的字母异位词 (opens new window)是求 字符串a 和 字符串b 是否可以相互组成,在383.赎金信 (opens new window)中是求字符串a能否组成字符串b,而不用管字符串b 能不能组成字符串a。

上面两道题目用map确实可以,但使用map的空间消耗要比数组大一些,因为map要维护红黑树或者符号表,而且还要做哈希函数的运算。所以数组更加简单直接有效!因此,能用数组的哈希法就用数组

set作为哈希表

(~)349.两个数组的交集

交集其实就是一个数组中出现的数值在另一个数组中也出现!因此要用哈希表!

但是由于这道题目没有限制数值(元素数值范围跨度比较大)的大小,就无法使用数组来做哈希表了。由于题目中说明了:结果唯一(即结果要求去重),且无序!因此选用unorder_set。

主要因为如下两点:

  • 数组的大小是有限的,受到系统栈空间(不是数据结构的栈)的限制。
  • 如果数组空间够大,但哈希值比较少、特别分散、跨度非常大,使用数组就造成空间的极大浪费。

所以此时一样的做映射的话,就可以使用set了。

关于set,C++ 给提供了如下三种可用的数据结构:(详情请看关于哈希表,你该了解这些! (opens new window)

  • std::set
  • std::multiset
  • std::unordered_set

std::set和std::multiset底层实现都是红黑树,std::unordered_set的底层实现是哈希, 使用unordered_set 读写效率是最高的,本题并不需要对数据进行排序,而且还不要让数据重复,所以选择unordered_set。另外应该注意:set用的是insert函数进行插入的

  • 3
    点赞
  • 7
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值