LeetCode438.找到字符串中所有字母异位词

因为之前写过一道找字母异位词分组的题,所以这道题做起来还是比较得心应手。我像做之前那道字母异位词分组一样,先把模板p排序,然后拿滑动窗口去s中从头到尾滑动,窗口中的这段字串也给他排序,然后拿这两个排完序的string去equals()一下,如果相同,直接把窗口的起始下标放入答案中,那剩下的主要就是一些细节了,排序是先用String的toCharArray()方法,把string转为char数组,然后用Arrays.sort()方法把字符数组排序,最后用String.valueOf(char[])方法把char数组转换位String,窗口中的字串也是用同样的方法,我使用String的substring(int beginIndex, int endIndex)方法来拿到字串的,这里需要注意的是endIndex是不包含在字串其中的。最后两个string比较equals一下就可以,以下是我的代码:

java 复制代码
class Solution {
    public List<Integer> findAnagrams(String s, String p) {
      List<Integer> ans = new ArrayList<Integer>();
      char[] c = p.toCharArray();
      Arrays.sort(c);
      String ss = String.valueOf(c);
      int l = c.length;
      int n = s.length();
      for(int i = 0;i<=n-l;i++){
         int j = i+l;
         if(j<=n){
            String sub = s.substring(i,j);
             char[] subc =sub.toCharArray();
            Arrays.sort(subc);
            String sub2 = String.valueOf(subc);
            if(sub2.equals(ss)){
                ans.add(i);
            }
         }else{
             break;
         }
      }
      return ans;
    }
}

看了一下题解,题解为了更高的算法执行效率并没有用排序,而是统计窗口中所有字母出现的次数与模板中所有字母出现的次数进行比较,如果出现的次数相同,那字串和模板就是异位词。

java 复制代码
class Solution {
    public List<Integer> findAnagrams(String s, String p) {
        int sLen = s.length(), pLen = p.length();

        if (sLen < pLen) {
            return new ArrayList<Integer>();
        }

        List<Integer> ans = new ArrayList<Integer>();
        int[] sCount = new int[26];
        int[] pCount = new int[26];
        for (int i = 0; i < pLen; ++i) {
            ++sCount[s.charAt(i) - 'a'];
            ++pCount[p.charAt(i) - 'a'];
        }

        if (Arrays.equals(sCount, pCount)) {
            ans.add(0);
        }

        for (int i = 0; i < sLen - pLen; ++i) {
            --sCount[s.charAt(i) - 'a'];
            ++sCount[s.charAt(i + pLen) - 'a'];

            if (Arrays.equals(sCount, pCount)) {
                ans.add(i + 1);
            }
        }

        return ans;
    }
}

他是创建两个大小位26的int数组scount和pcount,然后通过++sCount[s.charAt(i) - 'a'];统计字母出现的次数,然后也是通过窗口的特点,就是进来一个加上一个,出去一个减掉一个,所以可以发现,在第一次初始化完count数组后窗口不断右移,左边在把scount--,右边在把scount++。

相关推荐
故以往之不谏1 分钟前
JAVA--类和对象4.1--构造方法基础
java·开发语言·javascript
青瓷程序设计2 分钟前
【基于 YOLO的咖啡豆果实成熟度检测系统】+ Python+算法模型+目标检测+2026原创
python·算法·yolo
014-code2 分钟前
Java Optional 那些被忽略的用法
java·数据库·javase
程序员Shawn3 分钟前
【机器学习 | 第七篇】- 聚类算法
算法·机器学习·聚类
A 小码农4 分钟前
亲测AI智能小助手-IDEA中使用腾讯混元大模型
java·人工智能·intellij-idea
eggwyw5 分钟前
redis 使用
java
ERBU DISH7 分钟前
ChatGLM2-6B模型推理流程和模型架构详解
java
地平线开发者9 分钟前
征程 6X watchdog 问题分析
算法·自动驾驶
像素猎人11 分钟前
蓝桥杯OJ716【限定第一步和最后一步爬台阶的经典例题】【动态规划】
c++·算法·动态规划
BullSmall11 分钟前
IntelliJ IDEA 安装与环境配置指南(2026 最新)
java·ide·intellij-idea