当前位置:网站首页>力扣383-赎金信——哈希映射数组法
力扣383-赎金信——哈希映射数组法
2022-08-09 18:54:00 【张怼怼√】
题目描述
给你两个字符串:ransomNote 和 magazine ,判断 ransomNote 能不能由 magazine 里面的字符构成。
如果可以,返回 true ;否则返回 false 。
magazine 中的每个字符只能在 ransomNote 中使用一次。
求解思路
首先我们需要明白一点:magazine有可能比randomNote长,且包含的字母多;
所以先将这两个字符串通过 toCharArray() 方法转为为字符数组;
创建一个长度为26的字符映射数组 arr ,保存每个字母在字符数组中出现的次数;
首先需要遍历比较长的数组magazine,将每个元素出现次数保存至 arr 中;
其次,遍历 randomNate,将字母的出现次数在 arr 中减掉;
最后遍历 arr 如果有 arr[ i ] 有小于 0 的 ,说明 randomNote 中存在 magazine 中没有的字母。
输入输出示例

代码
class Solution {
public boolean canConstruct(String ransomNote, String magazine) {
char[] ran = ransomNote.toCharArray();
char[] mag = magazine.toCharArray();
int[] arr = new int[26];
for(char i : mag){
arr[i - 'a'] += 1;
}
for(char i : ran){
arr[i - 'a'] -= 1;
}
for(int i : arr){
if( i < 0) return false;
}
return true;
}
}边栏推荐
猜你喜欢
随机推荐
[Free Column] Android Fragment Injection for Android Security
Oracle 字段自增
真香|持一建证书央企可破格录取
ebook download | "Business executives' IT strategy guide - why enterprises should implement DevOps"
『百日百题 · 基础篇』备战面试,坚持刷题 第五话——循环语句(2)!
基于CC2530 E18-MS1-PCB Zigbee DIY作品(三)
EsgynDB Troubleshooting - ERROR[2012] Server process tdm_arkesp could not becreated
基于Web的疫情隔离区订餐系统
ClickHouse一种高性能分布式join查询模型(Colocate Join)
基于CC2530 E18-MS1-PCB Zigbee DIY作品(二)
华为云全流程护航《流浪方舟》破竹首发,打造口碑爆款
面试官:MySQL 中 update 更新,数据与原数据相同时会执行吗?大部分人答不上来!
2022.08.05_每日一题
基于设计稿识别的可视化低代码系统实践
php删除字符串的空格
看完这波 Android 面试题;助你斩获心中 offer
[免费专栏] Android安全之APK动态方式逆向应用【三种Smali注入方法】
Flume (五) --------- 自定义 Interceptor、自定义 Source 与 自定义 Sink
[] free column Android run Android, her - as command of safety
MFC tutorial









