LeetCode 242. 有效的字母异位词

Posted xiaoXingcode-go

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了LeetCode 242. 有效的字母异位词相关的知识,希望对你有一定的参考价值。

题目链接:LeetCode 242. 有效的字母异位词

题意:

本题是要判断两个字符串 s 和 t,是否是字母异位词,所谓字母异位次就是 如果 s 和 t 中每个字符出现的次数都相同,则称 s 和 t 互为字母异位词。

解题思路:

首先我们很容易想到,最简单的思路就是先遍历一遍s字符串,统计出每个字母出现的次数,然后同样的遍历t字符串,统计出每个字母出现的次数,

最后判断两个字符串中,每个字母出现的次数是否是相同的。

代码如下:

func isAnagram(s string, t string) bool 
 
    if len(s)!=len(t)
        return false
    
    ss:=make([]int,26)
    tt:=make([]int,26)

    for i,_:=range s
        ss[s[i]-\'a\']++
    
    for i,_:=range t
        tt[t[i]-\'a\']++
    
   
    for i:=0;i<26;i++
        if ss[i]!=tt[i]
            return false
        
    
    return true


其实上面代码看着比较啰嗦,由于字母总共也就是26个小写字母,因此只用一个数组来记录每个字母出现的次数即可,

代码如下:

func isAnagram(s string, t string) bool 

    //遍历s,每出现一个字母,对应的值+1,
    //遍历t,每出现一个字母,对应的值-1,
    //原数组是否恢复到声明时的状态。
    // 最后判断 m 数组如果有的元素不为零0,说明字符串s和t一定是谁多了字符或者谁少了字符,return false。
    // 最后如果 m 数组所有元素都为零0,说明字符串s和t是字母异位词,return true。

    m:=[26]int   //用来上记录字符串s里字符出现的次数。
    for i,_ := range s
         m[s[i]-\'a\'] ++
     
    for i,_ :=range t
       m[t[i] - \'a\']--
    
    return m == [26]int


前端与算法 leetcode 242. 有效的字母异位词

# 前端与算法 leetcode 242. 有效的字母异位词

题目描述

给定两个字符串 s 和 t ,编写一个函数来判断 t 是否是 s 的字母异位词。

示例?1:

输入: s = "anagram", t = "nagaram"
输出: true

示例 2:

输入: s = "rat", t = "car"
输出: false
说明:
你可以假设字符串只包含小写字母。

进阶:
如果输入字符串包含 unicode 字符怎么办?你能否调整你的解法来应对这种情况?

242. 有效的字母异位词

概要

判断异位词的方法很多,可以用哈希表,也可以构建26个字符数组判断,还可以根据每个字符出现的次数排序后判断字符串是否相等

提示

哈希,数组

解析

解法一:哈希表

哈希表在本题中表现一般,但看到这题时往往第一时间就能想到这个办法.构建一个HashMap然后统计s中每个单词出现的次数,随后用这个表去判断第t中所有字符出现的次数,一旦字符出现的次数不相等或者没有这个字符就返回false

解法二:数组判断字符出现次数

构建一个长度为26的数组然后全部填充0,随后s中的s[i]字符出现一次该下标位置的数字就自加一次,t[i]对应的下标自减一次,最后的结果中有一个不为0则表示s和t不相等

解法三:转换字符串

和解法二思路类似,但其实就是排序后判断字符串是否相等

算法

/**
 * @param {string} s
 * @param {string} t
 * @return {boolean}
 */
var isAnagram = function (s, t) {
  // 哈希法
  // if (s.length !== t.length) {return false;}
  // let map = new Map();
  // for (let i = 0;i < s.length;i++) {
  //   map.get(s[i]) === undefined ? map.set(s[i], 1) : map.set(s[i], map.get(s[i]) + 1);
  // }
  // for (let j = 0;j < t.length;j++) {
  //   if (map.get(t[j]) > 0) {map.set(t[j], (map.get(t[j])) - 1);} else {return false;}
  // }
  // return true;
  // 26个字符法
  if (s.length !== t.length) {return false;}
  let kmap = new Array(26).fill(0);
  for (let i = 0 ;i < s.length;i++) {
    kmap[s[i].charCodeAt(0) - 97]++;
    kmap[t[i].charCodeAt(0) - 97]--;
  }
  for (let i = 0;i < 26;i++) {
    if (kmap[i] !== 0) {return false;}
  }
  return true;
  // 解法三
  // if (s.length !== t.length) return false
  // let o = new Array(26).fill(0)
  // for (let i = 0; i < s.length; i++) {
  //   o[s[i].charCodeAt(0) - 97]++
  // }
  // let p = new Array(26).fill(0)
  // for (let i = 0; i < t.length; i++) {
  //   p[t[i].charCodeAt(0) - 97]++
  // }
  // o = o.toString()
  // p = p.toString()
  // return o === p
};

传入测试用例的运行结果

input:"rat","art"
output:true

执行结果

执行用时 :68 ms, 在所有 javascript 提交中击败了98.28%的用户
内存消耗 :35.7 MB, 在所有 javascript 提交中击败了87.50%的用户

GitHub仓库

242. 有效的字母异位词

以上是关于LeetCode 242. 有效的字母异位词的主要内容,如果未能解决你的问题,请参考以下文章

LeetCode-242-有效的字母异位词

leetCode242 有效的字母异位词

LeetCode 242. 有效的字母异位词

LeetCode 242. 有效的字母异位词(Valid Anagram)

leetcode 242 有效的字母异位词(Easy)

leetcode-242-有效的字母异位词