【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)。

收获

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

最近更新

  1. docker php8.1+nginx base 镜像 dockerfile 配置

    2024-01-18 01:02:02       98 阅读
  2. Could not load dynamic library ‘cudart64_100.dll‘

    2024-01-18 01:02:02       106 阅读
  3. 在Django里面运行非项目文件

    2024-01-18 01:02:02       87 阅读
  4. Python语言-面向对象

    2024-01-18 01:02:02       96 阅读

热门阅读

  1. 【学习笔记】[AGC063E] Child to Parent

    2024-01-18 01:02:02       52 阅读
  2. CSS基础

    CSS基础

    2024-01-18 01:02:02      40 阅读
  3. 第三章 计算机网络技术基础——教案(附PPT)

    2024-01-18 01:02:02       54 阅读
  4. Python: network:sip: pyVoIP;sip测试工具

    2024-01-18 01:02:02       53 阅读
  5. Python:list列表与tuple元组的区别

    2024-01-18 01:02:02       57 阅读
  6. 阿里云大数据ACA及ACP复习题(121~140)

    2024-01-18 01:02:02       52 阅读
  7. c++ STL标准库容器

    2024-01-18 01:02:02       60 阅读