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

网站开发后端最新技术网站开发书

网站开发后端最新技术,网站开发书,怎么自己设计房子效果图,建设工程个人信息采集哪个网站1. 问题描述 给你一个字符串 s 、一个字符串 t 。返回 s 中涵盖 t 所有字符的最小子串。如果 s 中不存在涵盖 t 所有字符的子串#xff0c;则返回空字符串 “” 。 注意#xff1a; 对于 t 中重复字符#xff0c;我们寻找的子字符串中该字符数量必须不少于 t 中该字符数量…1. 问题描述 给你一个字符串 s 、一个字符串 t 。返回 s 中涵盖 t 所有字符的最小子串。如果 s 中不存在涵盖 t 所有字符的子串则返回空字符串 “” 。 注意 对于 t 中重复字符我们寻找的子字符串中该字符数量必须不少于 t 中该字符数量。 如果 s 中存在这样的子串我们保证它是唯一的答案。 示例 1 输入s “ADOBECODEBANC”, t “ABC” 输出“BANC” 解释最小覆盖子串 “BANC” 包含来自字符串 t 的 ‘A’、‘B’ 和 ‘C’。 示例 2 输入s “a”, t “a” 输出“a” 解释整个字符串 s 是最小覆盖子串。 示例 3: 输入: s “a”, t “aa” 输出: “” 解释: t 中两个字符 ‘a’ 均应包含在 s 的子串中 因此没有符合条件的子字符串返回空字符串。 2. 思路 题目要求寻找最小连续子串那么第一个反应就是用滑动窗口求解。滑动窗口移动思路如下 如果当前滑动窗口内没有涵盖t中的所有字符那么窗口的右侧指针继续向右移动扩大窗口。如果当前滑动窗口内涵盖了t中的所有字符那么窗口的左侧指针可以向右移动缩小窗口寻找最小子串直到滑动窗口内无法涵盖t中的所有字符。 移动思路其实比较容易得到那么还有几个问题 由于t中会有重复字符因此我们应该记录t中各个字符的数量。拿什么记录如何判断当前滑动窗口涵盖了t中的所有字符 我一开始的思路是用HashMap字符当作key个数当作value。把字符串t和当前窗口都用两个Map表示。判断当前滑动窗口涵盖了t中的所有字符就将两个map中的键值对都拿出来一一比较只要当前窗口Map的value都大于等于t字符串那就说明涵盖。但这样有个问题我个人对map的遍历取值操作不太熟悉而且感觉使用Map有点重那么有没有别的数据结构可以代替呢 突然想起来可以用数组而且数组在存放时也可以达到O(1)在这道题和Map似乎没有差别。思路如下 由于本题字符串中只有英文字母因此我可以根据ASCII码建立一个数组数组长度就是’A’ - a’的值。这样每一个字符就有固定对应的存放位置可以保存他出现的次数。还是将字符串t和当前窗口都用两个数组表示。判断当前滑动窗口是否涵盖了t中的所有字符那就只需要对两个数组进行比较当前窗口的数组中的每个位置的元素都应该大于等于t字符串。这个操作就很简单了。 3. 代码 public String minWindow(String s, String t) {//滑动窗口的左指针int left 0;//记录最小字串的长度int minLen 100001;//记录最小子串的起始位置int start 0;//t字符串抽象成的数组保存每一个字符出现的次数int[] tArray new int[58];for(int i 0; i t.length(); i) {tArray[t.charAt(i) - A];}//当前滑动窗口抽象成的数组保存每一个字符出现的次数int[] temp new int[58];for(int right 0; right s.length(); right) {//先将这个字符加入到滑动窗口中temp[s.charAt(right) - A];//如果滑动窗口涵盖了字符串twhile(concludeT(temp, tArray)) {//更新最小子串if(minLen right - left 1) {minLen right - left 1;start left;}//左指针向右移动temp[s.charAt(left) - A]--;left;}}return minLen 100001 ? : s.substring(start, start minLen);}//判断当前滑动窗口是否涵盖了t字符串private Boolean concludeT(int[] temp, int[] tArray) {for(int i 0; i temp.length; i) {if(temp[i] tArray[i]) {return false;}}return true;}
http://www.dnsts.com.cn/news/43844.html

相关文章:

  • 网站建设方案评标原则小榄网站建设推广
  • 肇庆网站建设方案外包拼多多网络营销方式
  • 聊城做网站的地方网站后台和前台
  • 免费网站备案网站域名销售
  • 广安门内网站建设公司在选择网站时应考虑什么
  • 个人网站心得百度搜不到WordPress文章
  • wordpress图片整站商务网站规划与设计实训报告
  • wordpress站点是什么1688货源网下载app
  • 网站主页设计注意点中国菲律宾地图全图
  • wordpress在线更新要多久搭建网站seo
  • 对企业网站建设的建议怎么用ftp备份网站
  • 哪些网站做视频能赚钱营销型企业网站的含义
  • 做外贸无网站如何做俄罗斯最新
  • 黄江网站设计注册企业邮箱免费
  • 建设网站青岛市广告设计公司招聘
  • 域名 备案 没有网站注册监理工程师注册查询系统
  • 平凉市网站建设网站作业
  • 网站建设企业类型是什么科协网站建设建议
  • 网站建设沧州中国企业网信息查询
  • 网站宣传方案广东东莞直播基地
  • 做系统用哪个网站好安康升降平台
  • 电销做网站项目鸿蒙系统软件开发教程
  • 网站开发需要什么专业知识nodejs网站开发教程
  • 如何向百度提交网站海会主机
  • 衡阳城乡建设局网站wordpress弹框登陆
  • 屏蔽网站接口js广告wordpress文字模板下载
  • 网站建设嘉兴公司电话公司网上注册
  • 电子商务网站开发计划书招c1驾驶员300元一天
  • 网站建设与维护教学计划公司图标设计大全免费 logo
  • 深圳网站建设如何制作域名iis网站添加