解题思路
- 依次遍历s和t,将s中出现的字符依次填入哈希表中,出现一次则加1;
- 将t中出现的字符依次从哈希表中删去,出现一次则减1;
- 最后判断哈希表中是否有小于0的元素,若小于0则返回false,否则返回true。
C代码实现
bool isAnagram(char * s, char * t){
int len_s = strlen(s), len_t = strlen(t);
if(len_s != len_t){
return false;
}
// 设置哈希表,初始化为0
int hashTable[26] = {0};
// 将s中的各字符出现次数依次 填入 哈希表对应的格子中
for(int i=0;i<len_s;i++){
hashTable[s[i] - 'a']++;
}
// 将t中的各字符依次从哈希表对应的格子中 删去
for(int i=0;i<len_t;i++){
hashTable[t[i] - 'a']--;
if(hashTable[t[i] - 'a'] < 0){
return false;
}
}
return true;
}
Java代码实现--数组
class Solution {
public boolean isAnagram(String s, String t) {
int len1 = s.length();
int len2 = t.length();
if(len1 != len2) {
return false;
}
int[] res = new int[26];
for(int i=0; i<len1; i++) {
res[s.charAt(i) - 'a']++;
}
for(int i=0; i<len2; i++) {
res[t.charAt(i) - 'a']--;
}
for(int i=0; i<26; i++) {
if(res[i] < 0) {
return false;
}
}
return true;
}
}
Java代码实现--hashMap
class Solution {
public boolean isAnagram(String s, String t) {
int len1 = s.length();
int len2 = t.length();
if(len1 != len2) {
return false;
}
HashMap<Character, Integer> hashmap = new HashMap<>();
for(int i=0; i<len1; i++) {
char c1 = s.charAt(i);
if(hashmap.containsKey(c1)) {
// hashMap中包含当前字符
hashmap.replace(c1, hashmap.get(c1)+1);
} else {
// hashMap中不包含当前字符
hashmap.put(c1, 1);
}
}
for(int j=0; j<len2; j++) {
char c2 = t.charAt(j);
if(hashmap.containsKey(c2)) {
hashmap.replace(c2, hashmap.get(c2)-1);
if(hashmap.get(c2) < 0) {
return false;
}
} else {
return false;
}
}
return true;
}
}
参考资料:
- 242. 有效的字母异位词
- Java HashMap
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 终于写完轮子一部分:tcp代理 了,记录一下
· 震惊!C++程序真的从main开始吗?99%的程序员都答错了
· 别再用vector<bool>了!Google高级工程师:这可能是STL最大的设计失误
· 单元测试从入门到精通
· 【硬核科普】Trae如何「偷看」你的代码?零基础破解AI编程运行原理