242.有效的字母异位词

image.png
思路

字符a-z的ASCII码是26个连续的数值, a的ascii码为97 - a 相当于 a的下标是0,
那么a-z都减去a, 那就是0-25, 我们让其数值++就可以统计出字母a出现次数,
让s字符统一++, t字符串统一--
最后遍历数组看是否有大于0的下标 有的话就不是异位词

其实我们不需要记住ascii码是多少, 只需要让所以字符对应的ascii存入数组让该下表的数++即可

    public boolean isAnagram(String s, String t) {
           int[] record = new int[26];

        for (int i = 0; i < t.length(); i++) {
            record[t.charAt(i) - 'a']++;
        }

        for (int i = 0; i < s.length(); i++) {
            record[s.charAt(i) - 'a']--;
        }

        for (int i = 0; i < record.length; i++) {
            if (record[i] != 0) return false;
        }

        return true;
    }
        HashMap<String, Integer> map = new HashMap<String, Integer>();
        for (int i = 0; i < s.length(); i++) {
            char c = s.charAt(i);
            String str = String.valueOf(c);
            map.put(str, map.getOrDefault(str,0) + 1);
        }

        for (int i = 0; i < t.length(); i++) {
            char c = t.charAt(i);
            String s1 = String.valueOf(c);
            map.put(s1, map.getOrDefault(s1, 0) -1);
        }

        for (int var :map.values()) {
            if (var != 0) return false;
        }
        return true;
    }
©著作权归作者所有,转载或内容合作请联系作者
【社区内容提示】社区部分内容疑似由AI辅助生成,浏览时请结合常识与多方信息审慎甄别。
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

相关阅读更多精彩内容

友情链接更多精彩内容