leetcode 383. 赎金信
一、题目
给你两个字符串:ransomNote 和 magazine ,判断 ransomNote 能不能由 magazine 里面的字符构成。
如果可以,返回 true ;否则返回 false 。
magazine 中的每个字符只能在 ransomNote 中使用一次。
示例 1:
输入:ransomNote = "a", magazine = "b"
输出:false
ransomNote 和 magazine 由小写英文字母组成
二、解法
本题可以用哈希表。但由于只有小写字母,故用一个数组即可,时间更快
func canConstruct(ransomNote string, magazine string) bool {
var m [26]int
for _,ch:=range magazine{
m[ch-'a']++
}
for _,ch:=range ransomNote{
if m[ch-'a']>=1{
m[ch-'a']--
}else{
return false
}
}
return true
}

浙公网安备 33010602011771号