【力扣每日一题】力扣383赎金信

题目来源

力扣383赎金信

题目概述

给你两个字符串:ransomNotemagazine ,判断 ransomNote 能不能由 magazine 里面的字符构成。 如果可以,返回 true ;否则返回 falsemagazine 中的每个字符只能在 ransomNote 中使用一次。

示例

示例 1:

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

输出:false

示例 2:

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

输出:false

示例 3:

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

输出:true

提示

  • 1 <= ransomNote.length, magazine.length <= 10^5
  • ransomNote 和 magazine 由小写英文字母组成

思路分析

这个题目挺简单的,用一个长度为26的数组记录每个字母出现的次数,对比ransomNote中的字母及次数是否不大于magazine中对应字母出现的次数即可。

代码实现

java实现

java 复制代码
public class Solution {
    public boolean canConstruct(String ransomNote, String magazine) {
        int rLength = ransomNote.length();
        int mLength = magazine.length();
        if (rLength > mLength) {
            return false;
        }
        int[] rest = new int[26];
        int count = 0;
        for(int i = 0; i < rLength; i++) {
            rest[ransomNote.charAt(i) - 'a']++;
            count++;
        }
        for (int i = 0; i < mLength; i++) {
            int current = magazine.charAt(i) - 'a';
            if (rest[current] > 0) {
                count--;
                if (count == 0) {
                    return true;
                }
            }
            rest[current]--;
        }
        return false;
    }

}

c++实现

cpp 复制代码
class Solution {
public:
    bool canConstruct(string ransomNote, string magazine) {
        int rLength = ransomNote.length();
        int mLength = magazine.length();
        if (rLength > mLength) return false;

        int rest[26] = { 0 };
        int count = 0;
        for (int i = 0; i < rLength; i++) {
            rest[ransomNote[i] - 'a']++;
            count++;
        }
        for (int i = 0; i < mLength; i++) {
            int current = magazine[i] - 'a';
            if (rest[current] > 0){
                if ((--count)==0) {
                    return true;
                }
            }
            rest[current]--;
        }
        return false;
    }
};
相关推荐
Zevalin爱灰灰5 小时前
现代密码学 第二章——流密码【下】
算法·密码学
MY_TEUCK7 小时前
【Java 后端】SpringBoot 登录认证与会话跟踪实战(JWT + Filter/Interceptor)
java·开发语言·spring boot
飞Link7 小时前
大模型长文本的“救命稻草”:深度解析 TurboQuant 与 KV Cache 压缩技术
算法
今天长肉了吗7 小时前
银行风控项目踩坑实录:指标跑了6小时,风险评分全挂了
java
随读手机8 小时前
多式联运信息交互平台完整方案(2026版)
java·ai·eclipse·云计算·区块链
郝学胜-神的一滴8 小时前
深度学习优化核心:梯度下降与网络训练全解析
数据结构·人工智能·python·深度学习·算法·机器学习
Je1lyfish8 小时前
CMU15-445 (2025 Fall/2026 Spring) Project#3 - QueryExecution
linux·c语言·开发语言·数据结构·数据库·c++·算法
许彰午8 小时前
03-二叉树——从递归遍历到非递归实现
java·算法
nj01288 小时前
Spring 循环依赖详解:三级缓存、早期引用、AOP 代理与懒加载
java·spring·缓存
Brilliantwxx8 小时前
【C++】 vector(代码实现+坑点讲解)
开发语言·c++·笔记·算法