【LeetCode】383. 赎金信(简单)——代码随想录算法训练营Day07

题目链接:383. 赎金信

题目描述

给你两个字符串:ransomNotemagazine ,判断 ransomNote 能不能由 magazine 里面的字符构成。

如果可以,返回 true ;否则返回 false

magazine 中的每个字符只能在 ransomNote 中使用一次。

示例 1:

**输入:**ransomNote = "a", magazine = "b"

**输出:**false

示例 2:

**输入:**ransomNote = "aa", magazine = "ab"

**输出:**false

示例 3:

**输入:**ransomNote = "aa", magazine = "aab"

**输出:**true

提示:

  • 1 <= ransomNote.length, magazine.length <= 105
  • ransomNotemagazine 由小写英文字母组成

文章讲解:代码随想录

题解1:哈希表

思路:题目中提到两个字符串由小写字母组成,因此可以把长度为数组用作哈希表存储 magazine 中的每个字符出现的次数。再遍历 ransomNote,在哈希表中查找有没有足够的当前字符。

javascript 复制代码
/**
 * @param {string} ransomNote
 * @param {string} magazine
 * @return {boolean}
 */
var canConstruct = function(ransomNote, magazine) {
    const arr = new Array(26).fill(0);
    for (const i in magazine) {
        arr[magazine.charCodeAt(i) - "a".charCodeAt()]++;
    }
    for (const i in ransomNote) {
        if (arr[ransomNote.charCodeAt(i) - "a".charCodeAt()]) {
            arr[ransomNote.charCodeAt(i) - "a".charCodeAt()]--
        } else {
            return false;
        }
    }
    return true;
};

分析:时间复杂度为 O(n),空间复杂度为 O(1)。

收获

当判断一个元素有没有有在集合中时,就可以使用哈希表。

相关推荐
lihihi2 小时前
P1209 [USACO1.3] 修理牛棚 Barn Repair
算法
weixin_387534222 小时前
Ownership - Rust Hardcore Head to Toe
开发语言·后端·算法·rust
庞轩px2 小时前
MinorGC的完整流程与复制算法深度解析
java·jvm·算法·性能优化
Queenie_Charlie2 小时前
Manacher算法
c++·算法·manacher
闻缺陷则喜何志丹2 小时前
【树的直径 离散化】 P7807 魔力滋生|普及+
c++·算法·洛谷·离散化·树的直径
AI_Ming2 小时前
Seq2Seq-大模型知识点(程序员转行AI大模型学习)
算法·ai编程
若水不如远方2 小时前
分布式一致性(六):拥抱可用性 —— 最终一致性与 Gossip 协议
分布式·后端·算法
计算机安禾2 小时前
【C语言程序设计】第35篇:文件的打开、关闭与读写操作
c语言·开发语言·c++·vscode·算法·visual studio code·visual studio
Wect3 小时前
React Hooks 核心原理
前端·算法·typescript
美式请加冰3 小时前
字符串的介绍和使用
算法