242 有效的字母异位词
给定两个字符串 s 和 t ,编写一个函数来判断 t 是否是 s 的字母异位词。
注意:若 s 和 t 中每个字符出现的次数都相同,则称 s 和 t 互为字母异位词。
可以用字典的方法,判断两个字典是否相等就可,注意defaultdict的使用,可以直接给不存在的键添加进去不报错。
也可以用数组的方法,就是去计算s中每个字母出现的频率做加法,然后计算t中的字母频率做减法,如果最后的数组中所有的值都是0说明两个字符串是异位字符串,否则就不是。这里统计频率是计算字母的ASCII数值差找到字母相应索引位置然后加1或者减1。
from collections import defaultdict
class Solution:
def isAnagram(self, s: str, t: str) -> bool:
#字典+for循环
#defaultdict是Python内建dict类的一个子类,第一个参数为default_factory属性提供初始值,默认为None。它覆盖一个方法并添加一个可写实例变量。它的其他功能与dict相同,但会为一个不存在的键提供默认值,从而避免KeyError异常。
dict_s = defaultdict(int)
dict_t = defaultdict(int)
for i in s:
dict_s[i] += 1
for j in t:
dict_t[j] += 1
return dict_t == dict_s
#数组的方法
# record = [0] * 26
# for i in range(len(s)):
# record[ord(s[i]) - ord('a')] += 1 #ord() 函数是 chr() 函数(对于8位的ASCII字符串)
# for j in range(len(t)):
# record[ord(t[j]) - ord('a')] -= 1
# for x in range(26):
# if record[x] != 0: return False
# else: return True