剑指Offer|LCR 014. 字符串的排列

LCR 014. 字符串的排列

给定两个字符串 s1s2,写一个函数来判断 s2 是否包含 s1 的某个变位词。

换句话说,第一个字符串的排列之一是第二个字符串的 子串

示例 1:

复制代码
输入: s1 = "ab" s2 = "eidbaooo"
输出: True
解释: s2 包含 s1 的排列之一 ("ba").

示例 2:

复制代码
输入: s1= "ab" s2 = "eidboaoo"
输出: False

提示:

  • 1 <= s1.length, s2.length <= 104
  • s1s2 仅包含小写字母

法1:滑动窗口

分析:

建立一个hash表,键是26个字母,对应值是各自出现的次数,为方便键0就代表a,1代表b这样。

看例子:s1 = "ab" s2 = "eidbaooo"

表格中没写的都是填充0。接着遍历后面的s2

i=2,遍历s2中的d,

counts[s2.charCodeAt(i) - 'a'.charCodeAt(0)]--=counts[d-a]--=counts[3]--

counts[s2.charCodeAt(i - s1.length) - 'a'.charCodeAt(0)]++=counts[e-a]++=counts[4]++

i=3,遍历s2中的b

counts[s2.charCodeAt(i) - 'a'.charCodeAt(0)]--=counts[b-a]--=counts[1]--

counts[s2.charCodeAt(i - s1.length) - 'a'.charCodeAt(0)]++=counts[i-a]++=counts[8]++

i=4,遍历s2中的a

counts[s2.charCodeAt(i) - 'a'.charCodeAt(0)]--=counts[a-a]--=counts[0]--

counts[s2.charCodeAt(i - s1.length) - 'a'.charCodeAt(0)]++=counts[d-a]++=counts[3]++

到这,counts全都为0,就返回true

js 复制代码
 var checkInclusion = function(s1, s2) {
    if (s2.length < s1.length)  return false;

    let counts = new Array(26).fill(0);
    // 初始填充 counts 数组
    for (let i = 0; i < s1.length; ++i) {
        counts[s1.charCodeAt(i) - 'a'.charCodeAt(0)]++; // s1 计数 ++
        counts[s2.charCodeAt(i) - 'a'.charCodeAt(0)]--; // s2 计数 --
    }
    // 检查是否已匹配
    if (areAllZero(counts)) {
        return true;
    }

    // 滑动窗口
    // 滑动窗口的大小始终为 s1.length。
    for (let i = s1.length; i < s2.length; ++i) {
        counts[s2.charCodeAt(i) - 'a'.charCodeAt(0)]--;
        counts[s2.charCodeAt(i - s1.length) - 'a'.charCodeAt(0)]++;

        if (areAllZero(counts)) {
            return true;
        }
    }
};

/**
 * 辅助函数:检查 counts 数组是否全部为零
 * @param {number[]} counts
 * @return {boolean}
 */
function areAllZero(counts) {
    for (let count of counts) {
        if (count !== 0) {
            return false;
        }
    }
    return true;
}
相关推荐
Gyoku Mint25 分钟前
机器学习×第二卷:概念下篇——她不再只是模仿,而是开始决定怎么靠近你
人工智能·python·算法·机器学习·pandas·ai编程·matplotlib
dancing99927 分钟前
cocos3.X的oops框架oops-plugin-excel-to-json改进兼容多表单导出功能
前端·javascript·typescript·游戏程序
纪元A梦28 分钟前
分布式拜占庭容错算法——PBFT算法深度解析
java·分布式·算法
px不是xp1 小时前
山东大学算法设计与分析复习笔记
笔记·算法·贪心算法·动态规划·图搜索算法
萌萌哒草头将军1 小时前
🚀🚀🚀Prisma 发布无 Rust 引擎预览版,安装和使用更轻量;支持任何 ORM 连接引擎;支持自动备份...
前端·javascript·vue.js
书语时1 小时前
ES6 Promise 状态机
前端·javascript·es6
枫景Maple2 小时前
LeetCode 2297. 跳跃游戏 VIII(中等)
算法·leetcode
鑫鑫向栄2 小时前
[蓝桥杯]修改数组
数据结构·c++·算法·蓝桥杯·动态规划
鑫鑫向栄2 小时前
[蓝桥杯]带分数
数据结构·c++·算法·职场和发展·蓝桥杯