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

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;
}
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
【社区内容提示】社区部分内容疑似由AI辅助生成,浏览时请结合常识与多方信息审慎甄别。
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

友情链接更多精彩内容