Leetcode:242.有效的字母异位词

跟着carl学算法,本系列博客仅做个人记录,建议大家都去看carl本人的博客,写的真的很好的!
代码随想录
Leetcode:242.有效的字母异位词

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

示例 1:

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

输出: true

示例 2:

输入: s = "rat", t = "car"

输出: false

在这种题型中可以将数组set,map都可以看做是hash表aASCII是97,字符串中每个值直接映射到数组的某个位置上,然后计数,最后若数组每个位置都还是0则说明是有效的字母异位词

java 复制代码
	public boolean isAnagram(String s, String t) {
        if(s.length() != t.length())
            return false;
        int[] hash = new int[26];
        for(int i = 0; i< s.length(); i++){
            hash[s.charAt(i) - 'a']++;
        }
        for(int j = 0; j < t.length(); j++){
            hash[t.charAt(j) - 'a']--;
        }
        for(int i = 0; i < 26; i++){
            if(hash[i] != 0){
                return false;
            }
        }
        return true;
    }

因为最开始就判断了长度,所以可以在一个循环里面统计两个字符串

java 复制代码
	public boolean isAnagram(String s, String t) {
        if(s.length() != t.length())
            return false;
        int[] hash = new int[26];
        for(int i = 0; i< s.length(); i++){
            hash[s.charAt(i) - 'a']++;
            hash[t.charAt(i) - 'a']--;
        }
        for(int i = 0; i < 26; i++){
            if(hash[i] != 0){
                return false;
            }
        }
        return true;
    }
相关推荐
刃神太酷啦1 小时前
排序--数据结构初阶(4)(C/C++)
c语言·数据结构·c++·算法·leetcode·深度优先·广度优先
凯子坚持 c1 小时前
深度解析算法之分治(归并)
算法·leetcode·职场和发展
PXM的算法星球7 小时前
【leetcode】3524 求出数组的X值1
算法·leetcode·职场和发展
椰羊~王小美10 小时前
LeetCode -- Flora -- edit 2025-04-27
算法·leetcode·职场和发展
流影ng11 小时前
C语言HashTable基本理解
c语言·哈希算法
熏鱼的小迷弟Liu12 小时前
【Redis】Redis Zset实现原理:跳表+哈希表的精妙设计
数据库·redis·散列表
mit6.82415 小时前
[Lc_week] 447 | 155 | Q1 | hash | pair {}调用
算法·leetcode·哈希算法·散列表
vim怎么退出18 小时前
43.验证二叉搜索树
前端·leetcode
编程绿豆侠19 小时前
力扣HOT100之链表:23. 合并 K 个升序链表
算法·leetcode·链表
OpenC++1 天前
【C++QT】Layout 布局管理控件详解
c++·经验分享·qt·leetcode