当前位置: 首页 > wzjs >正文

什么网站可以做PS 写论文兼职西安seo推广优化

什么网站可以做PS 写论文兼职,西安seo推广优化,长春网络推广优化,游戏开发公司哪家好文章目录 问题描述核心思路:滑动窗口 字符计数数组1. 字符计数数组2. 滑动窗口 算法步骤完整代码实现复杂度分析关键点总结类似问题 问题描述 给定两个字符串 s 和 p,要求找到 s 中所有是 p 的**字母异位词(Anagram)**的子串的起…

文章目录

    • 问题描述
    • 核心思路:滑动窗口 + 字符计数数组
      • 1. 字符计数数组
      • 2. 滑动窗口
    • 算法步骤
    • 完整代码实现
    • 复杂度分析
    • 关键点总结
    • 类似问题

问题描述

给定两个字符串 sp,要求找到 s 中所有是 p 的**字母异位词(Anagram)**的子串的起始索引。
字母异位词是指由相同字母重新排列形成的字符串(包含相同的字母且每个字母出现的次数相同)。
例如:

  • 输入:s = "cbaebabacd", p = "abc"
    输出:[0, 6]
    解释:s 中从索引 0 开始的 "cba" 和索引 6 开始的 "bac" 均为 "abc" 的异位词。

核心思路:滑动窗口 + 字符计数数组

1. 字符计数数组

  • 核心思想:通过固定长度的数组(长度26,对应26个小写字母)记录字符串中每个字符的出现次数。
  • 比较机制:若两个字符串的字符计数数组相同,则它们是字母异位词。

2. 滑动窗口

  • 窗口初始化:在 s 中初始化一个长度为 p.length() 的窗口。
  • 窗口滑动:每次向右移动窗口,移除左边界字符的计数,增加右边界字符的计数。
  • 实时比较:每次滑动后检查当前窗口的计数数组是否与 p 的计数数组一致。

算法步骤

  1. 边界处理:若 s 的长度小于 pp 为空,直接返回空列表。
  2. 初始化计数数组
    • pCount:统计 p 中每个字符的出现次数。
    • sCount:统计 s 中初始窗口(前 p.length() 个字符)的出现次数。
  3. 初始窗口检查:若初始窗口的计数与 p 一致,记录索引 0
  4. 滑动窗口遍历
    • 窗口每次右移一位,更新左边界字符的计数(减少)和右边界字符的计数(增加)。
    • 每次更新后检查计数数组是否匹配,若匹配则记录当前窗口的起始索引。

完整代码实现

import java.util.ArrayList;
import java.util.Arrays;
import java.util.List;public class Solution {public List<Integer> findAnagrams(String s, String p) {List<Integer> result = new ArrayList<>();int m = p.length();int n = s.length();// 边界条件处理if (m == 0 || n < m) {return result;}int[] pCount = new int[26]; // 记录p的字符计数int[] sCount = new int[26]; // 记录当前窗口的字符计数// 初始化p和s的初始窗口的字符计数for (int i = 0; i < m; i++) {pCount[p.charAt(i) - 'a']++;sCount[s.charAt(i) - 'a']++;}// 检查初始窗口是否匹配if (Arrays.equals(pCount, sCount)) {result.add(0);}// 滑动窗口:每次移动一位,更新sCount并检查for (int i = 1; i <= n - m; i++) {// 移除左边界字符的计数int leftChar = s.charAt(i - 1);sCount[leftChar - 'a']--;// 添加右边界字符的计数int rightChar = s.charAt(i + m - 1);sCount[rightChar - 'a']++;// 检查当前窗口是否匹配if (Arrays.equals(pCount, sCount)) {result.add(i);}}return result;}
}

复杂度分析

  • 时间复杂度O(n),其中 n 是字符串 s 的长度。
    滑动窗口遍历 s 需要 O(n),每次窗口操作(更新计数和比较)的时间为常数。
  • 空间复杂度O(1),使用固定长度的两个长度为26的数组。

关键点总结

  1. 字符计数数组:利用数组索引映射字符,快速统计字符出现次数。
  2. 滑动窗口优化:避免每次重新计算整个子串的计数,通过动态更新窗口边界字符的计数保证高效性。
  3. 边界处理:注意字符串长度不足时的直接返回逻辑。

类似问题

  • LeetCode 567. 字符串的排列:判断 s2 是否包含 s1 的排列。
  • LeetCode 76. 最小覆盖子串:寻找覆盖目标字符的最短子串。
http://www.dtcms.com/wzjs/393113.html

相关文章:

  • 佛山做网站制作seo怎么优化方法
  • 广州网站建设技术方案青岛网站设计
  • 顺德网站制作公司哪家好网页制作教程
  • 深圳营销网站建站公司新型营销方式
  • 网站建设和网站开发网站推广计划书范文500字
  • 中国网站建设公司排行百度网盘搜索引擎盘多多
  • 南宁建站公司模板安徽百度seo公司
  • 桂林昨晚发生的新闻重庆百度快照优化排名
  • 境外 色情网站百度网页入口官网
  • 政府网站建设如何做免费域名解析网站
  • 常州市做网站发布软文的平台
  • 知名网站开发自建站怎么推广
  • 关于做网站的调查问卷aso优化哪家好
  • 怎么黑人网站高级seo优化招聘
  • 深圳网站制作的公司怎么样今日头条新闻在线看
  • 电子商务网站建设课程设计思路黄冈地区免费网站推广平台
  • 泰安企业建站公司平台蔡甸seo排名公司
  • 网站和网页的概念百度自动搜索关键词软件
  • 汕头市澄海建设局门户网站网络整合营销公司
  • 公司做网站有什么好处直通车关键词优化
  • wordpress多站点用户互通百度人工客服电话怎么转人工
  • 北京 网站建设济南seo小黑seo
  • 最新网站源码网站域名注册查询
  • 怎样建设一个网站教学谷歌搜索引擎363入口
  • 手机端开发网站模板下载优化大师下载安装
  • 网站设计总结与心得体会武汉seo公司排名
  • 成都电子商务平台网站制作报价2022搜索引擎
  • 做网站 做手机app要学什么软件吸引人的微信软文
  • 洛阳航迪科技网站建设公司怎么样解封后中国死了多少人
  • 自己做短视频网站推广网站平台