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

网站开发费用报价表百度phcms wordpress

网站开发费用报价表百度,phcms wordpress,制作表白网站,wordpress edit lock滑动窗口 要区分最小和最大滑窗,内层while循环的条件和更新结果的地方 核心: 关键的区别在于,最大滑窗是在迭代右移右边界的过程中更新结果,而最小滑窗是在迭代右移左边界的过程中更新结果。 最小滑窗 给定数组 nums&#xff0…

滑动窗口

要区分最小和最大滑窗,内层while循环的条件和更新结果的地方

核心:

关键的区别在于,最大滑窗是在迭代右移右边界的过程中更新结果,而最小滑窗是在迭代右移左边界的过程中更新结果

最小滑窗

给定数组 nums,定义滑窗的左右边界 i, j,求满足某个条件的滑窗的最小长度。

while j < len(nums)://这个while也可用fori代替判断[i, j]是否满足条件while 满足条件:不断更新结果(注意在while内更新!)i += 1 (最大程度的压缩i,使得滑窗尽可能的小)j += 1

L209长度最小的子数组

  • 题目:给定一个含有 n 个正整数的数组和一个正整数 s ,找出该数组中满足其和 ≥ s 的长度最小的 连续 子数组,并返回其长度。如果不存在符合条件的子数组,返回 0。

    示例:

    输入:s = 7, nums = [2,3,1,2,4,3] 输出:2 解释:子数组 [4,3] 是该条件下的长度最小的子数组。

    提示:

    • 1 <= target <= 10^9
    • 1 <= nums.length <= 10^5
    • 1 <= nums[i] <= 10^5
  • leetcode_209

  • class Solution {// 滑动窗口public int minSubArrayLen(int s, int[] nums) {int left = 0;int sum = 0;int result = Integer.MAX_VALUE;for (int right = 0; right < nums.length; right++) {sum += nums[right];//这里要求的是最小子数组,所以这里的while是满足条件的//然后在while里面最大程度的压缩i(也就是左边界)while (sum >= s) {result = Math.min(result, right - left + 1);sum -= nums[left++];}}return result == Integer.MAX_VALUE ? 0 : result;}
    }
    

最大滑窗

给定数组 nums,定义滑窗的左右边界 i, j,求满足某个条件的滑窗的最大长度。

while j < len(nums):判断[i, j]是否满足条件while 不满足条件:i += 1 (最保守的压缩i,一旦满足条件了就退出压缩i的过程,使得滑窗尽可能的大)不断更新结果(注意在while外更新!)j += 1

L904水果成蓝

  • 你正在探访一家农场,农场从左到右种植了一排果树。这些树用一个整数数组 fruits 表示,其中 fruits[i] 是第 i 棵树上的水果 种类 。

    你想要尽可能多地收集水果。然而,农场的主人设定了一些严格的规矩,你必须按照要求采摘水果:

    你只有 两个 篮子,并且每个篮子只能装 单一类型 的水果。每个篮子能够装的水果总量没有限制。
    你可以选择任意一棵树开始采摘,你必须从 每棵 树(包括开始采摘的树)上 恰好摘一个水果 。采摘的水果应当符合篮子中的水果类型。每采摘一次,你将会向右移动到下一棵树,并继续采摘。
    一旦你走到某棵树前,但水果不符合篮子的水果类型,那么就必须停止采摘。
    给你一个整数数组 fruits ,返回你可以收集的水果的 最大 数目。

  • 白话题目:求只包含两种元素的最长连续子序列

  • class Solution {public int totalFruit(int[] fruits) {int n = fruits.length;Map<Integer, Integer> cnt = new HashMap<Integer, Integer>();int left = 0, ans = 0;for (int right = 0; right < n; ++right) {cnt.put(fruits[right], cnt.getOrDefault(fruits[right], 0) + 1);//注意这里的while是不满足条件的//并且这里统计的ans是在while外面进行更新的!!!!!//这个与上面的最小子数组有着本质区别while (cnt.size() > 2) {cnt.put(fruits[left], cnt.get(fruits[left]) - 1);if (cnt.get(fruits[left]) == 0) {cnt.remove(fruits[left]);}++left;}ans = Math.max(ans, right - left + 1);}return ans;}
    }
    

总结:

  • 第一题让求大于某个数的最小子数组长度

    • while里面最大限度的压缩,只要满足就压缩

    • while的条件是大于某个数(即满足题意),并且while每循环一次就更新一下result的长度

    •         while (sum >= s) {result = Math.min(result, right - left + 1);sum -= nums[left++];}
      
  • 第二题让求最多包含两类(<=2)的最长子序列长度

    • while里面最小程度的压缩

    • while里的条件是大于2(即与题意相反),并且是while结束后进行更新长度ans

    •         while (cnt.size() > 2) {cnt.put(fruits[left], cnt.get(fruits[left]) - 1);if (cnt.get(fruits[left]) == 0) {cnt.remove(fruits[left]);}++left;}ans = Math.max(ans, right - left + 1);
      
http://www.yayakq.cn/news/527192/

相关文章:

  • 加快网站收录燕莎做网站
  • 重庆模板网站建站网站建设 手机和pc
  • 宿迁做网站的公司外冈网站建设
  • name域名的网站西宁制作网站需要多少钱
  • 一个网站两个域名 seo湘潭网站
  • 有关网站建设的文章做旅游网站
  • wordpress修改之前发布文章的id石家庄seo代理
  • 南京浦口网站建设高端响应式网站
  • 高端网站设计报价二手车网站开发多少钱
  • 浏览器怎么设置不拦截任何网站企业名称怎么取
  • 仿163源码交易平台宽屏整站源码 网站模板交易平台源码如何速发布wordpress
  • 网站开发和浏览器兼容问题手机排行榜2021前十名性价比
  • 做网站不赚钱了网站开发基础与提高
  • 网站打开时的客户引导页品牌建设的最高境界是培育客户成为什么购买者
  • 网站开发设计总结及心得体会门户网站应该怎么做
  • 潮流资讯类网站建设策划网站做外链平台有哪些
  • 网站备案幕布尺寸服务器搭建网站用什么系统
  • 崂山网站建设友情链接是外链吗
  • 网站赚钱方法wordpress横向导航菜单主题
  • wordpress转移整站wordpress导航栏下拉菜单代码
  • dreamwearver怎么做静态网站网络策略
  • 手机网站开发要多久网页设计资料下载网站
  • 珠海网站建设那家好中国flash网站模板中心
  • 百度收录的网站已经失效网站收录量下降
  • 网站 编码文档想做个赚钱的网站不知道做那种
  • 网站布局分类上海南山做网站
  • 寻找南京帮助做网站的单位网站架构发展历程的思考和心得体会
  • 佛山网站建设公司哪家性价比高wordpress安装环境
  • 刘金鹏做网站下载爱南宁app下载
  • html做的网站排版导致乱码万网的app叫什么