有效字母异位词力扣--242

目录

题目

思路

代码


题目

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

示例 1:

复制代码
输入: s = "anagram", t = "nagaram"
输出: true

示例 2:

复制代码
输入: s = "rat", t = "car"
输出: false

思路

1.什么是异位词?

两个字符串中除了字母的顺序不一样以外,组成字符串的字母都一样。

2.怎么想到要使用哈希表?

相当于查找一个字母是否在集合中,自然想到哈希表。

3.暴力解法可否解出来?

用两个for循环,可以暴力解出来,时间复杂度是O(n^2)

4.用哈希表的思路

  • 关键是构造哈希函数,想到用一个数组存每个字母出现的次数,将出现的字母种类称作a,哈希表的长度称作b a不能大于b,特殊之处在于,是字母,且两个字符串都是小写的,a-z的ASCII码差为26,所以创建一个长度为26的就可以。
  • 先遍历一个字符串S,通过某种方式,找到存他的位置,出现一次位置上就+1,通过这种方法来得到他出现几次
  • 通过的方式:长度为26,所以数组必然是从0-25,只需要用得到的字母的ASCII码减去a的,就可以得到唯一确定的存储位置。
  • 接着遍历另一个字符串T,通过同样的方式找到唯一存储的位置索引,然后-1
  • 最后只需要遍历哈希表,如果所有元素都为0,那么返回true,否则不行(如果大于0,说明某个字母在S中出现比在T中多出现一次,如果小于0说明某个字母在T中比在S中多出现一次)

代码

java 复制代码
class Solution {
    public boolean isAnagram(String s, String t) {
        int[] c=new int[26];//创建长度为26的哈希表,让每个字母出现的次数都有唯一且确定的位置存放
        for(int i=0;i<s.length();i++){//遍历其中一个字符串
            c[s.charAt(i)-'a']++;//找到存放的位置,出现次数+1
        }
        for(int j=0;j<t.length();j++){//遍历另一个元素
            c[t.charAt(j)-'a']--;

        }
        for(int result:c){//遍历哈希表
            if(result!=0){
                return false;//不是
            }
           
        }  
         return true;//是
    } 
}
java 复制代码
class Solution {
    public boolean isAnagram(String s, String t) {
        if(s.length() != t.length())//长度不一样,必然不是
            return false;
        int[] alpha = new int[26];
        for(int i = 0; i< s.length(); i++) {//有了上述判断只需要遍历一个字符串就可以了
            alpha[s.charAt(i) - 'a'] ++;
            alpha[t.charAt(i) - 'a'] --;
        }
        for(int i=0;i<26;i++)
            if(alpha[i] != 0)
                return false;
        return true;
    }
}
相关推荐
zhougl9962 分钟前
OkHttp用法-Java调用http服务
java·http·okhttp
Hygge-star1 小时前
【数据结构】二分查找-LeftRightmost
java·数据结构·算法
张扬飞舞1 小时前
IntelliJ IDEA打开项目后,目录和文件都不显示,只显示pom.xml,怎样可以再显示出来?
xml·java·intellij-idea
oneDay++1 小时前
# IntelliJ IDEA企业版集成AI插件「通义灵码」全流程详解:从安装到实战
java·经验分享·学习·intellij-idea·学习方法
努力的小帅1 小时前
C++_STL_map与set
开发语言·数据结构·c++·学习·leetcode·刷题
长勺1 小时前
Spring Security vs Shiro vs Sa-Token
java·后端·spring
为美好的生活献上中指1 小时前
java每日精进 5.14【参数校验】
java·开发语言·spring boot·tomcat
qq_12498707532 小时前
原生小程序+springboot+vue+协同过滤算法的音乐推荐系统(源码+论文+讲解+安装+部署+调试)
java·spring boot·后端·小程序·毕业设计·课程设计·协同过滤
曾昭武2 小时前
IDEA怎么汉化&idea中文改回英文版
java·intellij-idea·idea汉化·idea怎么汉化·idea转回英文
绝美焦栖2 小时前
vue复杂数据类型多层嵌套的监听
前端·javascript·vue.js