美文网首页
子串——是否是排列(一)

子串——是否是排列(一)

作者: 旺叔叔 | 来源:发表于2018-11-22 15:56 被阅读0次

LeetCode_242_ValidAnagram

题目分析:

核心思路,检测t是否和s的字母种类以及相应个数完全一样。记录s各类字母的个数,然后在t中匹配。
记录的结构可以用map,不过因为字母全小写且仅有26个,那么可以用数组代替。
这个数组代替map的操作,是字符串类题目的基操。

解法:

public static boolean isAnagram(String s, String t) {
    if (s.length() != t.length()) return false;
    int m[] = new int[26];
    for (int i = 0; i < s.length(); ++i) ++m[s.charAt(i) - 'a'];
    for (int i = 0; i < t.length(); ++i) {
        if (--m[t.charAt(i) - 'a'] < 0) return false;
    }
    return true;
}

相关文章

网友评论

      本文标题:子串——是否是排列(一)

      本文链接:https://www.haomeiwen.com/subject/mpblqqtx.html