前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >LeetCode 训练场:242. 有效的字母异位词

LeetCode 训练场:242. 有效的字母异位词

作者头像
村雨遥
发布2022-06-15 10:10:19
1900
发布2022-06-15 10:10:19
举报
文章被收录于专栏:JavaPark

1. 题目

242. 有效的字母异位词

2. 描述

给定两个字符串 s 和 t ,编写一个函数来判断 t 是否是 s 的字母异位词。 示例 1: 输入: s = “anagram”, t = “nagaram” 输出: true 示例 2: 输入: s = “rat”, t = “car” 输出: false

3. 思路

  1. 首先长度对比,不同则不是
  2. 其次用一个长为 26 的数组来表示各个字符出现的次数
  3. 将出现在字符串 s 里的字符个数加 1
  4. 出现在字符串 t 里的字符个数减 1
  5. 最后判断每个小写字母的个数是否都为 0
  6. 此时主要是进行遍历操作,时间复杂度为
O(n)

4. 实现

代码语言:javascript
复制
public boolean isAnagram(String s, String t) {
    // 对比长度,长度不同则不是
    if (s.length() != t.length()) {
        return false;
    }

    /* 用一个长为 26 的数组来表示各个字符出现的次数
         *  将出现在字符串 s 里的字符个数加 1
         * 出现在字符串 t 里的字符个数减 1
         * 最后判断每个小写字母的个数是否都为 0
         */
    int[] chaCount = new int[26];
    for (int i = 0; i < s.length(); i++) {
        chaCount[s.charAt(i) - 'a']++;
        chaCount[t.charAt(i) - 'a']--;
    }
    for (int item : chaCount) {
        if (item != 0) {
            return false;
        }
    }

    return true;
}
本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
原始发表:2020-06-29,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 1. 题目
  • 2. 描述
  • 3. 思路
  • 4. 实现
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档