LeetCode 3637.三段式数组 I:一次遍历(三种实现)

【LetMeFly】3637.三段式数组 I:一次遍历(三种实现)

力扣题目链接:https://leetcode.cn/problems/trionic-array-i/

给你一个长度为 n 的整数数组 nums

如果存在索引 0 < p < q < n − 1,使得数组满足以下条件,则称其为 三段式数组(trionic)

  • nums[0...p] 严格 递增,
  • nums[p...q] 严格 递减,
  • nums[q...n − 1] 严格 递增。

如果 nums 是三段式数组,返回 true;否则,返回 false

示例 1:
输入: nums = [1,3,5,4,2,6]

输出: true

解释:

选择 p = 2, q = 4

  • nums[0...2] = [1, 3, 5] 严格递增 (1 < 3 < 5)。
  • nums[2...4] = [5, 4, 2] 严格递减 (5 > 4 > 2)。
  • nums[4...5] = [2, 6] 严格递增 (2 < 6)。

示例 2:
输入: nums = [2,1,3]

输出: false

解释:

无法选出能使数组满足三段式要求的 pq

提示:

  • 3 <= n <= 100
  • -1000 <= nums[i] <= 1000

解题方法:遍历

使用一个状态 s t a t e state state分别代表正在处于三个数组的那一段。

方法一:if-else

  • 如果之前处于第1段数组当前元素比上一个小,则跳转到第2段数组;
  • 如果之前处于第2段数组当前元素比上一个大,则跳转到第3段数组;
  • 如果之前处于第3段数组当前元素比上一个小,则返回false

最终如果处于第三段数组则返回true

方法二:累加 s t a t e state state

只要发生数组跳跃,就一定是"当前元素比上个且上个元素比上上个" 或 "当前元素比上个且上个元素比上上个",总之就是数组由增变减或由减变增,此时 s t a t e + 1 state+1 state+1。

最终如果处于第三段数组则返回true

What's more

  1. 记得特判 n u m s [ 1 ] nums[1] nums[1]和 n u m s [ 0 ] nums[0] nums[0]的大小
  2. 数组中不得出现相邻且相等的元素,记得特判

时空复杂度分析

  • 时间复杂度 O ( l e n ( n u m s ) ) O(len(nums)) O(len(nums))
  • 空间复杂度 O ( 1 ) O(1) O(1)

AC代码

C++ - 方法一
cpp 复制代码
/*
 * @LastEditTime: 2026-02-04 21:56:05
 */
class Solution {
public:
    bool isTrionic(vector<int>& nums) {
        int state = 0;
        if (nums[1] <= nums[0]) {
            return false;
        }
        for (int i = 2; i < nums.size(); i++) {
            if (nums[i] == nums[i - 1]) {
                return false;
            }
            if (state == 0) {
                if (nums[i] < nums[i - 1]) {
                    state = 1;
                }
            } else if (state == 1) {
                if (nums[i] > nums[i - 1]) {
                    state = 2;
                }
            } else if (state == 2) {
                if (nums[i] < nums[i - 1]) {
                    return false;
                }
            }
        }
        return state == 2;
    }
};
C++ - 方法一+if合并版
cpp 复制代码
/*
 * @Author: LetMeFly
 * @Date: 2026-02-04 21:57:20
 * @LastEditors: LetMeFly.xyz
 * @LastEditTime: 2026-02-04 21:58:07
 */
#if defined(_WIN32) || defined(__APPLE__)
#include "_[1,2]toVector.h"
#endif

class Solution {
public:
    bool isTrionic(vector<int>& nums) {
        int state = 0;
        if (nums[1] <= nums[0]) {
            return false;
        }
        for (int i = 2; i < nums.size(); i++) {
            if (nums[i] == nums[i - 1]) {
                return false;
            }
            if (state == 0 && nums[i] < nums[i - 1]) {
                state = 1;
            } else if (state == 1 && nums[i] > nums[i - 1]) {
                state = 2;
            } else if (state == 2 && nums[i] < nums[i - 1]) {
                return false;
            }
        }
        return state == 2;
    }
};
C++ - 方法二
cpp 复制代码
/*
 * @LastEditTime: 2026-02-04 22:02:00
 */
class Solution {
public:
    bool isTrionic(vector<int>& nums) {
        int state = 0;
        if (nums[1] <= nums[0]) {
            return false;
        }
        for (int i = 2; i < nums.size(); i++) {
            if (nums[i] == nums[i - 1]) {
                return false;
            }
            if ((nums[i] > nums[i - 1]) != (nums[i - 1] > nums[i - 2])) {
                state++;
                if (state > 2) {
                    return false;
                }
            }
        }
        return state == 2;
    }
};

同步发文于CSDN和我的个人博客,原创不易,转载经作者同意后请附上原文链接哦~

千篇源码题解已开源

相关推荐
岛雨QA10 小时前
查找算法「Java数据结构与算法学习笔记7」
数据结构·算法
宝贝儿好11 小时前
【强化学习】第十章:连续动作空间强化学习:随机高斯策略、DPG算法
人工智能·python·深度学习·算法·机器人
isyoungboy11 小时前
从图像中提取亚像素边缘点
算法
郝学胜-神的一滴11 小时前
深入理解链表:从基础到实践
开发语言·数据结构·c++·算法·链表·架构
岛雨QA11 小时前
排序算法「Java数据结构与算法学习笔记6」
数据结构·算法
熬夜有啥好11 小时前
Linux软件编程——综合小练习
linux·算法·目录遍历·fgets·strcpy·linux内核与用户交互·strtok
民乐团扒谱机11 小时前
【硬核解析】网易云听歌/哼歌识曲底层技术:从算法实现到工程落地(附核心公式/伪代码)
算法
Z9fish11 小时前
sse哈工大C语言编程练习23
c语言·数据结构·算法
ArturiaZ11 小时前
【day36】
数据结构·c++·算法
山河君11 小时前
四麦克风声源定位实战:基于 GCC-PHAT + 最小二乘法实现 DOA
算法·音视频·语音识别·信号处理·最小二乘法·tdoa