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

临海企业网站建设公司全国疫情实时资讯

临海企业网站建设公司,全国疫情实时资讯,深圳外贸网站优化哪家好,高效网站推广文章目录 1. 滑动窗口2. 举例2.1 无重复字符的最长子串2.2 长度最小的子数组2.3 滑动窗口最大值2.4 最小覆盖子串2.5 删除有序数组中的重复项 1. 滑动窗口 滑动窗口的大概思想如下: 可以通过两个指针来标识窗口的边界。窗口的长度是可以固定的,也可以是…

文章目录

    • 1. 滑动窗口
    • 2. 举例
      • 2.1 无重复字符的最长子串
      • 2.2 长度最小的子数组
      • 2.3 滑动窗口最大值
      • 2.4 最小覆盖子串
      • 2.5 删除有序数组中的重复项

1. 滑动窗口

  1. 滑动窗口的大概思想如下:
  1. 可以通过两个指针来标识窗口的边界。
  2. 窗口的长度是可以固定的,也可以是可变的,完全取决于求解的问题性质。
  3. 维护一个或者一组和窗口相关联的状态变量,能有效降低计算量和算法复杂度。
  1. 算法思想:什么是滑动窗口?

其实就是一个队列,比如例题中的 abcabcbb,进入这个队列(窗口)为 abc 满足题目要求,当再进入a,队列变成了 abca,这时候不满足要求。所以,我们要移动这个队列
如何移动?我们只要把队列的左边的元素移出就行了,直到满足题目要求

2. 举例

下面例子采用语言JAVA

2.1 无重复字符的最长子串

无重复字符的最长子串

class Solution {public int lengthOfLongestSubstring(String s) {int[] last = new int[128];for(int i = 0; i < 128; i++) {last[i] = -1;}int res = 0;int start = 0; // 窗口开始位置int n = s.length();for(int i = 0; i < s.length(); i++) {int index = s.charAt(i);start = Math.max(start, last[index]);//last[index]代表上一次出现的位置,但是字符串内字符不能重复,所以要从上一次出现位置的下一个位置开始//last[index]的存在是为了使得窗口滑动到下一个位置res   = Math.max(res, i - start + 1);//当前字符串个数 = 数据末指针-窗口初始位置+1last[index] = i+1;//窗口的下一个位置赋值}return res;}
}

2.2 长度最小的子数组

长度最小的子数组 && 参考文档

class Solution {public int minSubArrayLen(int target, int[] nums) {int i=0,j=0,sum=0,min = Integer.MAX_VALUE;while(i<nums.length){sum = sum +nums[i++];while(sum >= target){min = Math.min(min,i-j);sum = sum - nums[j++];}}return min == Integer.MAX_VALUE ? 0 : min;}
}

2.3 滑动窗口最大值

滑动窗口最大值

class Solution {public int[] maxSlidingWindow(int[] nums, int k) {int length = nums.length;int i = 0,j = 0;int out = length-k+1;//外循环次数 int []arr = new int[out];for(i = 0; i<out ; i++){int max = Integer.MIN_VALUE;for(j = i; j<i+k ; j++){max = Math.max(max,nums[j]);}arr[i] = max;}return arr;}
}

2.4 最小覆盖子串

最小覆盖子串 && 参考文旦

class Solution {public String minWindow(String s, String t) {HashMap<Character,Integer> hs = new HashMap<Character,Integer>();HashMap<Character,Integer> ht = new HashMap<Character,Integer>();for(int i = 0;i < t.length();i ++){ht.put(t.charAt(i),ht.getOrDefault(t.charAt(i), 0) + 1);}String ans = "";int len = 1000000, cnt = 0;  for(int i = 0,j = 0;i < s.length();i ++){hs.put(s.charAt(i), hs.getOrDefault(s.charAt(i), 0) + 1);if(ht.containsKey(s.charAt(i)) && hs.get(s.charAt(i)) <= ht.get(s.charAt(i))) cnt ++;while(j < i && (!ht.containsKey(s.charAt(j)) || hs.get(s.charAt(j)) > ht.get(s.charAt(j)))){int count = hs.get(s.charAt(j)) - 1;hs.put(s.charAt(j), count);j ++;}if(cnt == t.length() && i - j + 1 < len){len = i - j + 1;ans = s.substring(j,i + 1);}}return ans;}
}

2.5 删除有序数组中的重复项

删除有序数组中的重复项

class Solution {public int removeDuplicates(int[] nums) {int n = nums.length;if(n == 0) return 0;int fast = 1, slow = 1;while (fast < n) {if (nums[fast] != nums[fast - 1]) {nums[slow] = nums[fast];slow ++;}fast ++;}return slow;}
}
http://www.shuangfujiaoyu.com/news/19310.html

相关文章:

  • 网站建设实施过程百度网盘下载的文件在哪
  • 做网站找我图片新闻平台发布
  • 专业做网站方案优化网站排名软件
  • 技术支持 东莞网站建设家装seo综合查询平台官网
  • 免费看电视剧的网站有哪些软文撰写
  • 网站内的链接怎么做怎么在百度上推广自己的产品
  • 网站建设-易速通科技百度搜索优化关键词排名
  • 男的做直播网站google搜索网址
  • 三合一网站开发架构竞价排名服务
  • 男人的天堂哔哩哔哩seo快速排名培训
  • 汉南城乡建设局网站seo入门教程seo入门
  • 做网站如何赚钱知乎9个成功的市场营销案例
  • 做网站最好的公司网页设计软件有哪些
  • 珠海软件公司排名下列关于seo优化说法不正确的是
  • 武汉网站托管公司关键词长尾词优化
  • 少儿培训河南整站关键词排名优化软件
  • 湖南网站建设360o哪有免费的网站
  • 淘宝联盟填网站备案如何分析百度指数
  • 网站mip怎么做惠州百度seo在哪
  • 网站建设项目的实训报告企业网络推广的方法
  • 做网站设计提成赚钱吗免费学生网页制作成品代码
  • 个人网站链接怎么做友情链接属于免费推广吗
  • 自己做书画交易网站公司培训课程有哪些
  • 包头做网站百度词条优化
  • 阿里网站年费怎么做分录设计培训班学费一般多少
  • 建设建行积分兑换商城网站搜索引擎营销的成功案例
  • 网站建设错误要点网络营销的概念及内容
  • 做建材批发的网站推广引流方法有哪些推广方法
  • 网站备案备注怎么写做小程序公司哪家好
  • 汉中网站制作百度总部电话