首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

动态规划 —— 子数组系列-最长湍流子数组

最长湍流子数组 题目链接: 978....最长湍流子数组 - 力扣(LeetCode) https://leetcode.cn/problems/longest-turbulent-subarray/description/ 2....题目解析 假如有一个数组{a , b , c , d }如果在a这个位置,b比a大,呈上升趋势,c比b小,呈下降趋势,d比c大,呈上升趋势,像这种就是湍流子数组,简单来说就是必须的是上下上下或者下上下上...算法原理 状态表示:以某一个位置为结尾或者以某一个位置为起点 f[i]表示:以i位置为结尾的所有子数组中,最后一个位置呈上升状态下的最长湍流子数组的长度 g[i]表示:以i位置为结尾的所有子数组中...,最后一个位置呈下降状态下的最长湍流子数组的长度 2.

6810
  • 您找到你想要的搜索结果了吗?
    是的
    没有找到

    【leetcode速通java版】02——有序数组、子数组、螺旋矩阵

    前 言 作者简介:半旧518,长跑型选手,立志坚持写10年博客,专注于java后端 ☕专栏简介:代码随想录leetcode速通训练营java版本 文章简介:leetcode-T977有序数组的平方...,Leetcode-T209长度最小的子树组,Leetcode-T59螺旋矩阵二 文章目录 leetcode-T977有序数组的平方 leetcode-T209 长度最小的子数组 Leetcode-T59...螺旋矩阵II leetcode-T977有序数组的平方 解法一:暴力破解法 先将数组中的元素遍历变成平方,再进行冒泡排序。...,比如这道题目的数组元素有两边大,中间小的特点 2.双指针法灵活、高效、好用 leetcode-T209 长度最小的子数组 法1:暴力解决法 从第一个元素开始遍历数组元素累加,当累加值到达target...{ minLen = 0; } return minLen; } } 法2:滑动窗口法 所谓滑动窗口,就是不断的调整子序列的起始位置和终止位置

    31610

    DP:子数组问题

    引言 介绍动态规划(DP)在解决子数组问题上的重要性,以及本文的目的——通过具体问题的分析和代码示例,帮助读者理解如何用DP解决子数组问题。...子数组问题介绍 简要介绍什么是子数组问题,以及这些问题在实际应用中的重要性。例如,最大子数组和问题、最长递增子数组问题等。...关于子数组问题的几个题 1.最大子数组和 题目链接 题目: 样例输出和输入: 题目要求很简单,就是求出 最长的子数组的和,这个和有一个要求就是和最大。...f[i] = max(f[i - 1] + nums[i-1], nums[i-1]),g[i]也同理,g[i]为当前位置的子数组中最小的那个 子数组的和,所以i位置的子数组和的最小等于前一个位置的子数组和的最小...f[i]表示以i位置为结尾的子数组中的最大乘积的那个,g[i]表示以i位置为结尾的子数组中最小的乘积的那个。

    9210

    长度最小的子数组

    长度最小的子数组 给定一个含有n个正整数的数组和一个正整数s ,找出该数组中满足其和 ≥ s的长度最小的连续子数组,并返回其长度。如果不存在符合条件的连续子数组,返回0。...实例 输入: s = 7, nums = [2,3,1,2,4,3] 输出: 2 解释: 子数组 [4,3] 是该条件下的长度最小的连续子数组。...的时候尾指针不断右移,因为窗口间的值一直小于给定的s,只有尾指针右移扩大窗口才有可能使窗口间的值的和大于等于s,当窗口间值的和大于s时,那么就使首指针右移用以减小窗口的数量,只有不断减少窗口的数量才能获得长度最小的连续子数组...,当尾指针达到边界条件即尾指针超过了nums数组的长度,那么尾指针不再右移,此时将首指针不断右移,直到首指针的长度与nums数组的长度相等,结束循环,在最后判断target是否仍然等于无穷大,如果仍然是等于无穷大则认为没有找到合适的子数组长度并返回

    1.8K10

    连续子数组的最大和

    (A[0], A[1],…,A[n-1], A[n]),这个数组有很多连续子数组,那么其中数组之和的最大值是什么呢?...子数组必须是连续的。...要求时间复杂度O(n) 解题思路 方法一:暴力枚举子数组 思路 一个长度为n的数组,共有n(n+1)/2个子数组,计算出所有子数组的和,最快需要O(n^2)的时间复杂度,虽然完成了计算,但是时间复杂度不符合...方法二:找规律 思路 思路如原书给出的如下表格,主要思想是: 记录两个数,最大的子数组和+累加子数组和 遍历数组,随时更新最大的子数组和 一旦累加数为负数,直接放弃,将累加子数组和设置为0 ?...微信:yangzd1102 Github:@qqxx6661 个人博客: CSDN:@qqxx6661 知乎:@Zhendong 简书:@蛮三刀把刀 掘金:@蛮三刀把刀 原创博客主要内容 Java知识点复习全手册

    91420

    【动态规划】子数组系列(下)

    最长湍流子数组 978....最长湍流子数组 状态表示:先用 dp[i] 来表示以第 i 个位置为结尾时的最长湍流数组的长度 f[i]:表示以第 i 个位置为结尾时表示上升状态的最长湍流数组的长度 f[i]:表示以第 i 个位置为结尾时表示下降状态的最长湍流数组的长度...,上升也是一样的道理,需要在第 i - 1 位置处于下降状态,就是 g[i - 1] + 1,相等时等于 1 即可 初始化:由于 1 个元素也可以称为湍急子数组,所以可以把 0 下标初始化为 1,又因为状态转移方程中的其他情况是...环绕字符串中唯一的子字符串 467....,这就可能出现多次,例如“cac” 相同的子串只能统计一次,并且可以发现,以同一个字符结尾的子串只需要统计最长的即可,短的情况就包含在了长的情况,所以可以额外定义一个 hash 表来存储最终的答案,最后只需返回

    10710

    【动态规划】子数组系列(上)

    最大子数组和 状态表示:以 i 位置为结尾时的所有子数组中的最大和 状态转移方程: i 位置为结尾的子数组又可以分为长度为 1 的和大于 1 的,长度为 1 就是 nums[i] ,长度不为 1 就是...环形子数组的最大和 918....乘积最大子数组 这道题求的是乘积最大的子数组,由于是乘法,就意味着两个负数乘完之后也会变成整数 状态表示:先定义为以 i 位置为结尾时的所有子数组中的最大乘积发现,如果是负数的话也可以乘进来,所以可以定义两个状态...以 i 位置为结尾时的所有子数组中的最大乘积 以 i 位置为结尾时的所有子数组中的最小乘积 状态转移方程: 求 f[i] 时,如果说当前元素是一个负数,那么就需要乘上一个最小的负数,也就是 g[i -...乘积为正数的最长子数组长度 状态表示: f[i]:以 i 位置为结尾的所有子数组中乘积为正数的最长长度 g[i]:以 i 位置为结尾的所有子数组中乘积为负数的最长长度 状态转移方程: 还是和之前一样,可以分为长度为

    11610
    领券