来源:力扣(LeetCode)
链接:https://leetcode-cn.com/problems/valid-anagram
给定两个字符串 s 和 t ,编写一个函数来判断 t 是否是 s 的字母异位词。
注意:若 s 和 t 中每个字符出现的次数都相同,则称 s 和 t 互为字母异位词。
示例 1:
输入: s = “anagram”, t = “nagaram”
输出: true
示例 2:输入: s = “rat”, t = “car”
输出: false
提示:1 <= s.length, t.length <= 5 * 104 s 和 t 仅包含小写字母
参考文章:把数组当做哈希表来用,很巧妙!
思路:
这道题算是最简单的哈希表题目了吧,直接用数组做哈希表即可
另外在这里也说点与本题无关的,以后看到题目说判断一个元素是否重复出现,就要考虑使用哈希表
本题Java代码:
class Solution {
public boolean isAnagram(String s, String t) {
int[] record = new int[26];
for(char c : s.toCharArray()){
record[c - 'a']++;
}
for(char c : t.toCharArray()){
record[c - 'a']--;
}
for(int i : record){
if(i != 0)return false;
}
return true;
}
}