242. 有效的字母异位词

集合

import java.util.HashMap;

class Solution {
    public boolean isAnagram(String s, String t) {

        if (s.length() != t.length()){
            return false;
        }

        /**
         * 用HashMap存储s中字母及次数
         * 然后遍历t,找到相同的就减1,一旦次数小于0说明该字母的个数不相等
         * map.getOrDefault()方法可以一步判断元素是否存在以及赋值
         */
        HashMap<Character, Integer> map = new HashMap<>();

        for (int i = 0; i < s.length(); i++) {
            map.put(s.charAt(i), map.getOrDefault(s.charAt(i), 0) + 1);
        }

        for (int i = 0; i < t.length(); i++) {

            map.put(t.charAt(i), map.getOrDefault(t.charAt(i), 0) - 1);

            if (map.get(t.charAt(i)) < 0){
                return false;
            }
        }

        return true;
    }
}

/**
 * 时间复杂度 O(n)
 * 空间复杂度 O(n)
 */

哈希表

class Solution {
    public boolean isAnagram(String s, String t) {

        if (s.length() != t.length()){
            return false;
        }

        /**
         * 用哈希表存储s中所有小写字母的次数
         * 然后在t中进行寻找,只要有哪个字母的次数小于0则返回false
         */
        int[] hash = new int[128];

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

        for (int i = 0; i < t.length(); i++) {

            hash[t.charAt(i) - 'a']--;

            if (hash[t.charAt(i) - 'a'] < 0){
                return false;
            }
        }

        return true;
    }
}

/**
 * 时间复杂度 O(n)
 * 空间复杂度 O(1)
 */

https://leetcode-cn.com/problems/valid-anagram/submissions/

上一篇:在论坛中出现的比较难的sql问题:7(子查询 判断某个字段的值是否连续)


下一篇:java leetcode之[动态规划 中等]784. 字母大小写全排列