leetcode初级算法之————有效的字母异位词

这篇博客探讨了如何判断两个字符串是否为变位词(anagram),即字母出现次数相同。提供了两种解法:一是通过计数数组对比每个字母的频率,二是将字符串排序后比较。代码实现分别使用了计数数组和排序比较的方法,适用于字符串长度相等的情况。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

问题描述:判断两个字符串中字母出现的次数是否相同

如:add  dad : true ;  add art: false

解法一: 暴力解法

 思路:老生常谈地,使用两个长度为26的数组,统计两个单词每个字母的出现次数,再比较这两个字母即可

var isAnagram = function(s, t) {

    if(s.length != t.length) return false

    let count_s = new Array(26).fill(0)

    let count_t = new Array(26).fill(0)

    let i

    for(i = 0; i < s.length; i++){

        count_s[s[i].charCodeAt() - 96]++

        count_t[t[i].charCodeAt() - 96]++

    }

    for(i = 0; i < 26; i++){

        if(count_t[i] != count_s[i]) return false

    }

    return true

}

解法二:排序比较

 思路:先把字符串转化为数组,再排序,最后再转化回来比较是否相等。排序是排除顺序不一致造成的干扰

var isAnagram = function(s, t) {

    if(s.length != t.length) return false

    //将字符串转化为数组:以下两个种方式都行

    let s_Arr = Array.from(s)

    let t_Arr = t.split('')

    //数组排序sort()函数

    s_Arr.sort()

    t_Arr.sort()

    //数组转化为字符串,再判断是否相等:数组转化为字符串同样有两种方式,但是会有逗号分隔

    return s_Arr.toString() === t_Arr.join()

}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值