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

力扣hot100(9-找到字符串中所有字母异位词;10-和为K的子数组)

方法一:滑动窗口

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; } }

这里的难点是Arrays.equals(arr1,arr2)方法,我们指定equals默认底层是==,比较引用数据类型时只比较地址,而Arrays中的equals方法是比较数组内容是否完全一致,在这里可以用来检验字母异位词。

方法一:枚举

public class Solution { public int subarraySum(int[] nums, int k) { int count = 0; for (int start = 0; start < nums.length; ++start) { int sum = 0; for (int end = start; end >= 0; --end) { sum += nums[end]; if (sum == k) { count++; } } } return count; } }

方法二:前缀和+哈希表优化

public class Solution { public int subarraySum(int[] nums, int k) { int count = 0, pre = 0; HashMap < Integer, Integer > mp = new HashMap < > (); mp.put(0, 1); for (int i = 0; i < nums.length; i++) { pre += nums[i]; if (mp.containsKey(pre - k)) { count += mp.get(pre - k); } mp.put(pre, mp.getOrDefault(pre, 0) + 1); } return count; } }

key:前缀和 value:该前缀和出现的次数

http://www.jsqmd.com/news/699149/

相关文章:

  • Cursor Pro免费激活工具:跨平台设备标识重置技术方案
  • 2026年湖南长沙短视频运营与GEO豆包AI搜索推广深度横评|企业获客新赛道完全指南 - 年度推荐企业名录
  • 别再为音频格式发愁了!一个Java工具类搞定WAV转MP3、AMR转码(附完整代码和依赖配置)
  • 宪意(山东)建筑拆除:济南拆门窗服务商 - LYL仔仔
  • BarrageGrab:全平台直播弹幕抓取架构设计与企业级应用解决方案
  • 实测分享:3家在线平面设计公司对比,2026传媒/广告店线上设计辅助首选
  • open-xiaoai-bridge:让小爱同学语音控制任意智能设备
  • 南京乐意工程机械租赁:口碑好的南京叉车出租服务 - LYL仔仔
  • F5 NGINX Agent部署与运维实战:实现NGINX配置管理与监控自动化
  • 3分钟快速掌握AI视频水印移除技术:从技术原理到实战应用
  • 从头构建可审计合约项目:C++26 contracts + CMake + sanitizers + CI流水线(GitHub Actions一键部署版)
  • 为什么你的C++26合约始终不生效?深度解析__cpp_contracts宏、-fcontracts和-fcontract-continuation三者协同逻辑
  • 智能体工作流编排:基于图计算模型的复杂AI应用开发框架解析
  • Nuxt 2文档网站重构指南:如何用Docus打造高性能技术文档平台
  • 哈尔滨市道里区胜广建材:哈尔滨沙子出售优秀公司 - LYL仔仔
  • 从vue-print-nb到原生JS:我的前端打印功能选型踩坑实录与避坑指南
  • 西安市长安区鑫宝通建筑:西安钢管架搭建翻新公司 - LYL仔仔
  • 工业电源模块选型参考:钡特电源 DB1-05S03S 与 B0503S-1WR3 封装兼容解析
  • CGI脚本
  • OCS Inventory NG Windows Agent:自动化资产盘点的核心原理与实战部署指南
  • AI搜索时代,深圳企业正在被“隐身”?深圳本地GEO优化公司推荐 - 品牌评测官
  • 多层感知机(MLP)神经网络入门与实践指南
  • TensorRT LLM AutoDeploy:大模型推理优化自动化实践
  • Java 动态库开发和调试(JNI 和 FFM)
  • Wan2.2-I2V-A14B部署教程:LDAP统一认证对接企业SSO系统
  • 广州市黄埔区鑫邦租赁:广州二手空压机回收服务商 - LYL仔仔
  • 不容易晒黑的防晒霜推荐,Leeyo防晒霜硬核抗晒远离暗沉变黑 - 全网最美
  • 温岭市大溪致翔机械设备租赁:靠谱的台州吊车租赁公司 - LYL仔仔
  • 从订单履约到会员增长:游戏电竞护航陪玩源码系统小程序全开源 v4.0 解决方案 - 壹软科技
  • 3大场景解析:如何用Path of Building彻底改变你的流放之路Build规划思维?