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

收获

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

相关推荐
NAGNIP8 小时前
一文搞懂深度学习中的通用逼近定理!
人工智能·算法·面试
颜酱16 小时前
单调栈:从模板到实战
javascript·后端·算法
CoovallyAIHub19 小时前
仿生学突破:SILD模型如何让无人机在电力线迷宫中发现“隐形威胁”
深度学习·算法·计算机视觉
CoovallyAIHub19 小时前
从春晚机器人到零样本革命:YOLO26-Pose姿态估计实战指南
深度学习·算法·计算机视觉
CoovallyAIHub19 小时前
Le-DETR:省80%预训练数据,这个实时检测Transformer刷新SOTA|Georgia Tech & 北交大
深度学习·算法·计算机视觉
CoovallyAIHub20 小时前
强化学习凭什么比监督学习更聪明?RL的“聪明”并非来自算法,而是因为它学会了“挑食”
深度学习·算法·计算机视觉
CoovallyAIHub20 小时前
YOLO-IOD深度解析:打破实时增量目标检测的三重知识冲突
深度学习·算法·计算机视觉
NAGNIP1 天前
轻松搞懂全连接神经网络结构!
人工智能·算法·面试
NAGNIP1 天前
一文搞懂激活函数!
算法·面试
董董灿是个攻城狮1 天前
AI 视觉连载7:传统 CV 之高斯滤波实战
算法