今日学习的文章链接和视频链接
leetcode题目地址:383. 赎金信
代码随想录题解地址:代码随想录
题目简介
给你两个字符串:ransomNote
和 magazine
,判断 ransomNote
能不能由 magazine
里面的字符构成。
如果可以,返回 true
;否则返回 false
。
magazine
中的每个字符只能在 ransomNote
中使用一次。
看到题目的第一想法(可以贴代码)
- 利用Map来存储magazine里的元素及其出现的次数,再用ransomNote里的元素去"消耗它",若最后次数为 -1 或根本不存在该元素,则return false。
java
public boolean canConstruct(String ransomNote, String magazine) {
Map<Character, Integer> m = new HashMap<>();
char[] c1 = magazine.toCharArray();
char[] c2 = ransomNote.toCharArray();
for (char i : c1){
if (m.containsKey(i)){
int temp = m.get(i);
m.replace(i, ++temp);
}else {
m.put(i, 1);
}
}
for (char i : c2){
if (m.containsKey(i)){
int temp = m.get(i);
if (temp == 0) return false;
m.replace(i, --temp);
}else {
return false;
}
}
return true;
}
实现过程中遇到哪些困难
无
看完代码随想录之后的想法
【解题思路】以空间换取时间,用一个长度为26的数组来记录magazine里字母出现的次数。
然后再用ransomNote去验证这个数组是否包含了ransomNote所需要的所有字母。
依然是数组在哈希法中的应用。
【想法】
- 一些同学可能想,用数组干啥,都用map完事了,其实在本题的情况下,使用map的空间消耗要比数组大一些的,因为map要维护红黑树或者哈希表,而且还要做哈希函数,是费时的!数据量大的话就能体现出来差别了。 所以数组更加简单直接有效!
看完视频自己写的ACC:
java
public boolean canConstruct(String ransomNote, String magazine) {
int[] alph = new int[26];
char[] m = magazine.toCharArray();
char[] r = ransomNote.toCharArray();
for (char i : m){
alph[i-97]++;
}
for (char i : r){
alph[i-97]--;
if (alph[i-97] < 0) return false;
}
return true;
}
学习时长
12:50 ~ 13:05 解题成功
13:05 ~ 13:10 看视频题解、写博客
今日收获
- String的遍历:
① for循环直接遍历,强制转换成char类型
String str = "asdfghjkl";
for(int i=0;i<str.length();i++){
char ch = str.charAt(i);
}
② 转换成char[]遍历 GOOD!
char[] c=s.toCharArray();
for(char cc:c){
...//cc直接用了
}
③ 利用substring()函数
for(int i=0;i<str.length();i++){
String subStr = str.substring(i, i+1)
}