力扣 567. 字符串的排列

该博客讨论了一种使用滑动窗口算法来判断一个字符串是否包含另一个字符串的排列的方法。Python和Java的实现代码被提供,通过创建字符计数器并在字符串s2中移动窗口来检查s1的排列是否存在。示例展示了如何判断输入字符串如'ab'在'eidbaooo'或'eidboaoo'中作为排列出现。
摘要由CSDN通过智能技术生成
题目

给你两个字符串 s1 和 s2 ,写一个函数来判断 s2 是否包含 s1 的排列。如果是,返回 true ;否则,返回 false 。
换句话说,s1 的排列之一是 s2 的 子串 。

示例

输入:s1 = “ab” s2 = “eidbaooo”
输出:true
解释:s2 包含 s1 的排列之一 (“ba”).
示例 2:

输入:s1= “ab” s2 = “eidboaoo”
输出:false

来源:力扣(LeetCode)
链接:https://leetcode-cn.com/problems/permutation-in-string
著作权归领扣网络所有。商业转载请联系官方授权,非商业转载请注明出处。

方法1:滑动窗口

滑动窗口
在这里插入图片描述

Python实现

1、将s1存进c1。
2、每次在s2上移动 s1长度的窗口,并判断是否相等。

class Solution:
    def checkInclusion(self, s1: str, s2: str) -> bool:
        c1=collections.Counter(s1)
        n=len(s2)
        left=0
        right=len(s1)-1
        
        c2=collections.Counter(s2[left:right])
        while right<n:
            c2[s2[right]] += 1
            if c1==c2: return True

            c2[s2[left]] -=1
            if c2[s2[left]]==0: del c2[s2[left]]

            left+=1
            right+=1

        return False

在这里插入图片描述

⭐Java实现1

2021/11/9更新:
框架!!!

class Solution {
    public boolean checkInclusion(String s1, String s2) {
        Map<Character, Integer> need = new HashMap<>();
        Map<Character, Integer> window = new HashMap<>();

        for (int i = 0; i < s1.length(); i++){
            char c = s1.charAt(i);
            need.put(c, need.getOrDefault(c, 0) + 1);
        }

        int l = 0, r = 0, valid = 0;

        while (r < s2.length()){
            char c = s2.charAt(r);
            r++;
            if (need.containsKey(c)){
                window.put(c, window.getOrDefault(c, 0) + 1);
                if (window.get(c).equals(need.get(c))) valid++;
            }

            while (r - l == s1.length()){
                if (valid == need.size()) return true;
                char d = s2.charAt(l);
                l++;
                if (need.containsKey(d)){
                    if (need.get(d).equals(window.get(d))) valid--;
                    window.put(d, window.get(d) - 1);
                }
            }
        }
        return false;
    }
}

在这里插入图片描述

Java实现2

学到了2个map比较的方法! yyds啊

2021/11/9:
我去 这个10月26的代码写的啥子哦,我看半天没看懂,这真的是我本人写的?疑惑(・∀・

class Solution {
    public boolean checkInclusion(String s1, String s2) {
        Map<Character, Integer> map1 = new HashMap<>(); //对照窗口
        Map<Character, Integer> map2 = new HashMap<>(); //s2中的移动窗口
        int n=s2.length();
        int left=0, right=s1.length()-1;

        if (s1.length()>s2.length()) return false;

        for (int i=0; i<s1.length(); i++){
            if (!map1.containsKey(s1.charAt(i))) map1.put(s1.charAt(i), 1);
            else map1.put(s1.charAt(i), map1.get(s1.charAt(i))+1);
        }

        for (int i=0; i<s1.length(); i++){
            if (!map2.containsKey(s2.charAt(i))) map2.put(s2.charAt(i), 1);
            else map2.put(s2.charAt(i), map2.get(s2.charAt(i))+1);
        }


        while (right < n){
            if ((map1).equals(map2)) return true;

            //右边操作       
            right++;
            if (right==n) break;
            if (!map2.containsKey(s2.charAt(right))) map2.put(s2.charAt(right), 1);
            else map2.put(s2.charAt(right), map2.get(s2.charAt(right))+1);

            //左边操作
            map2.put(s2.charAt(left), map2.get(s2.charAt(left))-1);
            if (map2.get(s2.charAt(left))==0) map2.remove(s2.charAt(left));
            left++;
        }
        return false;
    }
}

在这里插入图片描述

评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值