LeetCode 3105.最长的严格递增或递减子数组

给你一个整数数组 nums

返回数组 nums严格递增严格递减的最长非空子数组的长度。

示例 1:

**输入:**nums = [1,4,3,3,2]

**输出:**2

解释:

nums 中严格递增的子数组有[1][2][3][3][4] 以及 [1,4]

nums 中严格递减的子数组有[1][2][3][3][4][3,2] 以及 [4,3]

因此,返回 2

示例 2:

**输入:**nums = [3,3,3,3]

**输出:**1

解释:

nums 中严格递增的子数组有 [3][3][3] 以及 [3]

nums 中严格递减的子数组有 [3][3][3] 以及 [3]

因此,返回 1

示例 3:

**输入:**nums = [3,2,1]

**输出:**3

解释:

nums 中严格递增的子数组有 [3][2] 以及 [1]

nums 中严格递减的子数组有 [3][2][1][3,2][2,1] 以及 [3,2,1]

因此,返回 3

提示:

  • 1 <= nums.length <= 50
  • 1 <= nums[i] <= 50

分组循环,严格递增或严格递减的为一组,找最长的组:

cpp 复制代码
class Solution {
public:
    int longestMonotonicSubarray(vector<int>& nums) {
        int n = nums.size();

        int ans = 0;

        int i = 0;
        while (i < n) {
            int start = i;
            ++i;
            while (i < n && (nums[i] - nums[i - 1]) * (nums[start + 1] - nums[start]) > 0) {
                ++i;
            }

            ans = max(ans, i - start);

            // 循环结束时,[start, i - 1]是严格递增或递减的
            // 下次循环从i - 1位置开始
            if (i < n && nums[i] != nums[i - 1]) {
                --i;
            }
        }

        return ans;
    }
};

如果nums的长度为n,则此算法时间复杂度为O(n),空间复杂度为O(1)。

相关推荐
科研小白_2 小时前
基于遗传算法优化BP神经网络(GA-BP)的数据时序预测
人工智能·算法·回归
Terry Cao 漕河泾2 小时前
基于dtw算法的动作、动态识别
算法
Miraitowa_cheems5 小时前
LeetCode算法日记 - Day 73: 最小路径和、地下城游戏
数据结构·算法·leetcode·职场和发展·深度优先·动态规划·推荐算法
野蛮人6号5 小时前
力扣热题100道之560和位K的子数组
数据结构·算法·leetcode
Swift社区6 小时前
LeetCode 400 - 第 N 位数字
算法·leetcode·职场和发展
fengfuyao9856 小时前
BCH码编译码仿真与误码率性能分析
算法
小白不想白a7 小时前
每日手撕算法--哈希映射/链表存储数求和
数据结构·算法
剪一朵云爱着7 小时前
力扣2080. 区间内查询数字的频率
算法·leetcode
落日漫游7 小时前
数据结构笔试核心考点
java·开发语言·算法
Dream it possible!8 小时前
LeetCode 面试经典 150_栈_有效的括号(52_20_C++_简单)(栈+哈希表)
c++·leetcode·面试··哈希表