题目链接:https://leetcode-cn.com/problems/valid-anagram/
题目描述:
给定两个字符串 s 和 t ,编写一个函数来判断 t 是否是 s 的字母异位词。
示例 1:
输入: s = "anagram", t = "nagaram"
输出: true
示例 2:
输入: s = "rat", t = "car"
输出: false
说明:
你可以假设字符串只包含小写字母。
解法一
将字符串转换为字符数组,进行排序,再比较是否相同。
class Solution {
public boolean isAnagram(String s, String t) {
char[] sChar = s.toCharArray();
char[] tChar = t.toCharArray();
Arrays.sort(sChar);
Arrays.sort(tChar);
return Arrays.equals(sChar,tChar);
}
}
解法二
通过一个数组来统计每个字母出现的频次
class Solution {
public boolean isAnagram(String s, String t) {
if(s.length() != t.length()) {
return false;
}
int[] count = new int[26];
for(int i=0;i<s.length();i++) {
count[s.charAt(i)-'a']++;
count[t.charAt(i)-'a']--;
}
for(int c:count) {
if(c!=0) {
return false;
}
}
return true;
}
}