[LeetCode]day20 383.赎金信

题目链接

题目描述

给你两个字符串:ransomNote 和 magazine ,判断 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

ransomNote 和 magazine 由小写英文字母组成


题解

这道题很简单 和[LeetCode]day16 242.有效的字母异位词可以说是一模一样了

审题

注意两个点

  • 每个字符只能出现一次 就是不能重复使用 有几个就用几个
  • 字符都是小写字母 范围比较小 只有26种情况 所以可以直接用数组下标来进行映射 也就是说 数组下标作为key,字符出现的频率作为value

解题

c 复制代码
class Solution {
public:
    bool canConstruct(string ransomNote, string magazine) {
        int array[26]={0};
        //统计magazine里面字符出现的频率
        for(int i=0;i<magazine.size();i++){
            array[magazine[i]-'a']++;
        }
        for(int i=0;i<ransomNote.size();i++){
            array[ransomNote[i]-'a']--;
        }
        
      
        for(int i=0;i<26;i++){
            if(array[i]<0) return false;
        }
        return true;
    }
};
相关推荐
Ring__Rain41 分钟前
c版的findcontours改写,输出为vector<vector<cPoint>>
算法
Yoyo25年秋招冲冲冲1 小时前
Day60_补20250208_图论part5_并查集理论基础|寻找存在的路径
java·开发语言·数据结构·算法·leetcode·动态规划·图论
不会敲代码的狗1 小时前
Acwing-基础算法课笔记之基础算法(差分)
笔记·算法
攻城狮7号2 小时前
【10.7】队列-解预算内的最多机器人数目
数据结构·c++·算法
Bran_Liu2 小时前
【LeetCode 刷题】动态规划(5)-子序列问题
python·算法·leetcode·动态规划
LNsupermali2 小时前
力扣1448. 统计二叉树中好节点的数目
算法·leetcode·职场和发展
硕风和炜2 小时前
【LeetCode: 8. 字符串转换整数 (atoi) + 模拟】
java·算法·leetcode·面试·模拟
一叶祇秋2 小时前
Leetcode - 149双周赛
算法·leetcode·职场和发展
会蹦的鱼2 小时前
算法15(力扣347)——前k个高频元素
算法·leetcode·职场和发展