一、leetcode567. 字符串的排列
给你两个字符串 s1 和 s2 ,写一个函数来判断 s2 是否包含 s1 的排列。如果是,返回 true ;否则,返回 false 。
换句话说,s1 的排列之一是 s2 的 子串 。
示例 1:
输入:s1 = “ab” s2 = “eidbaooo” 输出:true 解释:s2 包含 s1 的排列之一 (“ba”). 示例 2:
输入:s1= “ab” s2 = “eidboaoo” 输出:false
提示:
1 <= s1.length, s2.length <= 104 s1 和 s2 仅包含小写字母
用到滑动窗口知识,通过比较n1长度内的字符中种类来进行比较
import java.util.Arrays; class Solution { public boolean checkInclusion(String s1, String s2) { int n1 = s1.length(), n2 = s2.length(); if (n1 > n2) { return false; } int num1 [] = new int [26]; int num2 [] = new int [26]; for(int i =0;i<n1;i++){ num1[s1.charAt(i)-'a']++; num2[s2.charAt(i)-'a']++; } if(Arrays.equals(num1,num2)){ return true; } for(int i =n1;i<n2;i++){ num2[s2.charAt(i)-'a']++; num2[s2.charAt(i-n1)-'a']--; if(Arrays.equals(num1,num2)){ return true; } } return false; } }