leetcode_2909元素和最小的山形三元组

1. 题意

求 m i n ( a i + a j + a k ) , a j > a k , a j > a i , i < j < k min(a_i + a_j + a_k), a_j >a_k,a_j > a_i,i \lt j \lt k min(ai+aj+ak),aj>ak,aj>ai,i<j<k
元素和最小的山形三元组

2. 题解

枚举 j j j,求出 P r e M i n ( j − 1 ) PreMin(j - 1) PreMin(j−1)与 S u f M i n ( j + 1 ) SufMin(j +1) SufMin(j+1)

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

        vector<int> suf(sz);
        suf[sz - 1] = nums[sz - 1];
        for ( int i = sz - 2; ~i; --i ) {
            suf[i] = min(suf[i + 1], nums[i]);
        }

        int ans = -1;
        int pre = nums[0];
        for ( int i = 1; i < sz - 1; ++i ) {

            if ( nums[i] > pre && nums[i] > suf[i + 1]) {
                int sum = nums[i] + pre + suf[i + 1];
                if ( ans == -1)
                    ans = sum;
                else
                    ans = min(ans, sum);
            }
            pre = min(pre, nums[i]);
        }

        return ans;
    }
};
相关推荐
偷偷的卷20 分钟前
【算法笔记 day three】滑动窗口(其他类型)
数据结构·笔记·python·学习·算法·leetcode
北京地铁1号线26 分钟前
Zero-Shot(零样本学习),One-Shot(单样本学习),Few-Shot(少样本学习)概述
人工智能·算法·大模型
凤年徐1 小时前
【数据结构】时间复杂度和空间复杂度
c语言·数据结构·c++·笔记·算法
kualcal1 小时前
代码随想录17|二叉树的层序遍历|翻转二叉树|对称二叉树
数据结构·算法
满分观察网友z1 小时前
从混乱到有序:我用“逐层扫描”法优雅搞定公司组织架构图(515. 在每个树行中找最大值)
后端·算法
Z字小熊饼干爱吃保安2 小时前
面试技术问题总结一
数据库·面试·职场和发展
满分观察网友z2 小时前
一行代码的惊人魔力:从小白到大神,我用递归思想解决了TB级数据难题(3304. 找出第 K 个字符 I)
后端·算法
运维开发王义杰2 小时前
打破技术债困境:从“保持现状”到成为变革的推动者
运维·职场和发展
字节卷动2 小时前
【牛客刷题】活动安排
java·算法·牛客
yi.Ist2 小时前
数据结构 —— 键值对 map
数据结构·算法