【leetcode】383. 赎金信(easy)

给你两个字符串:ransomNote 和 magazine ,判断 ransomNote 能不能由 magazine 里面的字符构成。

如果可以,返回 true ;否则返回 false 。

magazine 中的每个字符只能在 ransomNote 中使用一次。

java 复制代码
class Solution {
    public boolean canConstruct(String ransomNote, String magazine) {
        HashMap<Character,Integer> hm = new HashMap<>();
        for(int i=0;i<magazine.length();i++){
            char a = magazine.charAt(i);
            if(hm.containsKey(a))
                hm.put(a, hm.get(a)+1);
            else
                hm.put(a,0);
        }

        for(int i=0; i<ransomNote.length(); i++){
            char b = ransomNote.charAt(i);
            // hm不包含b, 返回false
            if(!hm.containsKey(b))
                return false;
            // hm包含b, 若可使用次数不足, 返回false
            if(hm.get(b)<0)
                return false;
            // hm包含b且可使用,更新可使用次数
            hm.put(b, hm.get(b)-1);
        }
        return true;
    }
}
相关推荐
追随者永远是胜利者12 分钟前
(LeetCode-Hot100)169. 多数元素
java·算法·leetcode·go
s砚山s20 分钟前
代码随想录刷题——二叉树篇(二十)
算法
蜜獾云23 分钟前
JAVA面试题速记-第1期-java基础
java·开发语言
百锦再40 分钟前
Java中的反射机制详解:从原理到实践的全面剖析
java·开发语言·jvm·spring boot·struts·spring cloud·kafka
没有bug.的程序员1 小时前
Gradle 构建优化深度探秘:从 Java 核心到底层 Android 物理性能压榨实战指南
android·java·开发语言·分布式·缓存·gradle
-Rane1 小时前
【C++】vector
开发语言·c++·算法
tianyagukechat1 小时前
rockylinux9.5 配置IP
java·网络·tcp/ip
代码栈上的思考1 小时前
滑动窗口算法实战
算法
程序员Sonder1 小时前
黑马java----正则表达式(一文弄懂)
java·正则表达式·新人首发
doris82041 小时前
Python 正则表达式 re.findall()
java·python·正则表达式