【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;
    }
}
相关推荐
IronMurphy几秒前
【算法三十四】39. 组合总和
算法·深度优先
重庆小透明几秒前
力扣刷题【3】相交链表
算法·leetcode·链表
算法鑫探几秒前
C语言实战:学生成绩统计与分析
c语言·数据结构·算法·新人首发
IAUTOMOBILE3 分钟前
Code Marathon 项目源码解析与技术实践
java·前端·算法
Flying pigs~~3 分钟前
基于Deepseek大模型API完成文本分类预测功能
java·前端·人工智能·python·langchain·deepseek
Lyyaoo.3 分钟前
【JAVA基础面经】深拷贝与浅拷贝
java·开发语言·算法
oyzz12010 分钟前
Redis 安装及配置教程(Windows)【安装】
java
YNCAH_16 分钟前
特殊类的设计
java·开发语言
商吉婆尼22 分钟前
天地图API调用注意事项
java·spring·天地图
x_xbx27 分钟前
LeetCode:202. 快乐数
算法·leetcode·职场和发展