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

收获

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

相关推荐
闻缺陷则喜何志丹6 分钟前
【背包 组合】P7552 [COCI 2020/2021 #6] Anagramistica|普及+
c++·算法·背包·洛谷·组合
小章UPUP1 小时前
2026年第十六届MathorCup数学应用挑战赛D题国奖思路
算法
hssfscv1 小时前
软件设计师下午试题四——C语言(N皇后问题、分治、动态规划)
c语言·算法·动态规划
lolo大魔王1 小时前
Go语言的反射机制
开发语言·后端·算法·golang
白羊by1 小时前
Softmax 激活函数详解:从数学原理到应用场景
网络·人工智能·深度学习·算法·损失函数
故事和你911 小时前
洛谷-算法1-7-搜索3
数据结构·c++·算法·leetcode·动态规划
chipsense2 小时前
霍尔电流传感器选型方法论再升级:从800V平台到TMR竞争的全场景决策树
算法·决策树·机器学习·闭环霍尔·tmr传感
CoderYanger2 小时前
14届蓝桥杯省赛Java A 组Q1~Q3
java·开发语言·线性代数·算法·职场和发展·蓝桥杯
会编程的土豆3 小时前
【日常做题】 代码随想录(岛屿最大面积+寻宝)
数据结构·算法·图论
阿洛学长3 小时前
汉洛塔结构思维
算法