每日一题 2369

2369. 检查数组是否存在有效划分

题目描述:

给你一个下标从 0 开始的整数数组 nums ,你必须将数组划分为一个或多个 连续 子数组。

如果获得的这些子数组中每个都能满足下述条件之一 ,则可以称其为数组的一种 有效 划分:

  1. 子数组 2 个相等元素组成,例如,子数组 [2,2]
  2. 子数组 3 个相等元素组成,例如,子数组 [4,4,4]
  3. 子数组 3 个连续递增元素组成,并且相邻元素之间的差值为 1 。例如,子数组 [3,4,5] ,但是子数组 [1,3,5] 不符合要求。

如果数组 至少 存在一种有效划分,返回 true,否则,返回 false

示例 1:

复制代码
输入:nums = [4,4,4,5,6]
输出:true
解释:数组可以划分成子数组 [4,4] 和 [4,5,6] 。
这是一种有效划分,所以返回 true 。

示例 2:

复制代码
输入:nums = [1,1,1,2]
输出:false
解释:该数组不存在有效划分。

提示:

  • 2 <= nums.length <= 10^5
  • 1 <= nums[i] <= 10^6

思路:

感觉子串的题很多都是滑动窗口?

这一二条有重合的部分,想象如果满足二必定满足一,所以只需要判断一是否满足,如果是,则直接跳出;不满足一也不可能满足二,直接不用判断条件二了;一判断结束,开始判断三。

没试出来,直奔题解,哦,dp

代码:

复制代码
class Solution {
    public boolean validPartition(int[] nums) {
        int n =nums.length;
        boolean[] f=new boolean[n+1];
        f[0]=true;
        for(int i=1;i<n;i++){
            if (f[i - 1] && nums[i] == nums[i - 1] ||
                i > 1 && f[i - 2] && (nums[i] == nums[i - 1] && nums[i] == nums[i - 2] ||
                                      nums[i] == nums[i - 1] + 1 && nums[i] == nums[i - 2] + 2)) {
                f[i + 1] = true;
                }
        }
        return f[n];
    }
}
相关推荐
数字化脑洞实验室6 分钟前
如何理解不同行业AI决策系统的功能差异?
大数据·人工智能·算法
潼心1412o3 小时前
数据结构(长期更新)第5讲:单链表算法题
数据结构
小白菜又菜3 小时前
Leetcode 3370. Smallest Number With All Set Bits
算法·leetcode·职场和发展
星谷罗殇4 小时前
(七)TRPO 算法 & PPO 算法
算法·机器学习
国服第二切图仔5 小时前
Rust开发之使用Trait对象实现多态
开发语言·算法·rust
电鱼智能的电小鱼6 小时前
基于电鱼 ARM 工控机的井下AI故障诊断方案——让煤矿远程监控更智能、更精准
网络·arm开发·人工智能·算法·边缘计算
s砚山s6 小时前
代码随想录刷题——二叉树篇(一)
c++·算法·leetcode
小十一再加一6 小时前
【数据结构初阶】单链表
数据结构
ZIM学编程8 小时前
「学长有话说」作为一个大三学长,我想对大一计算机专业学生说这些!
java·c语言·数据结构·c++·python·学习·php
贝塔实验室9 小时前
LDPC 码的构造方法
算法·fpga开发·硬件工程·动态规划·信息与通信·信号处理·基带工程