242 有效的字母异位词

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
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值