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

题目链接:383. 赎金信

题目描述

给你两个字符串:ransomNote 和 magazine ,判断 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
  • ransomNote 和 magazine 由小写英文字母组成

文章讲解:代码随想录

题解1:哈希表

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

/**
 * @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)。

收获

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

你可能感兴趣的:(代码随想录算法训练营,#,LeetCode,哈希表,算法,代码随想录算法训练营,哈希表)