leetcode 3507. 移除最小数对使数组有序 I

给你一个数组 nums,你可以执行以下操作任意次数:

  • 选择 相邻 元素对中 和最小 的一对。如果存在多个这样的对,选择最左边的一个。
  • 用它们的和替换这对元素。

返回将数组变为 非递减 所需的 最小操作次数

如果一个数组中每个元素都大于或等于它前一个元素(如果存在的话),则称该数组为非递减

示例 1:

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

输出: 2

解释:

  • 元素对 (3,1) 的和最小,为 4。替换后 nums = [5,2,4]
  • 元素对 (2,4) 的和为 6。替换后 nums = [5,6]

数组 nums 在两次操作后变为非递减。

示例 2:

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

输出: 0

解释:

数组 nums 已经是非递减的。

提示:

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

分析:数据量很小,可以直接暴力模拟。

cpp 复制代码
int minimumPairRemoval(int* nums, int numsSize) {
    int ans=0,ind=0,f=1,cnt=numsSize;
    while(f)
    {
        f=0;
        int mini=60000;
        for(int i=1;i<cnt;++i)
        {
            if(nums[i]<nums[i-1])f=1;
            if(nums[i]+nums[i-1]<mini)mini=nums[i]+nums[i-1],ind=i-1;
        }
        if(f)
        {
            ans++;
            for(int i=0,t=0;i<cnt;++i,++t)
            {
                if(i!=ind)nums[t]=nums[i];
                else nums[t]=nums[i]+nums[i+1],++i;
            }
            cnt--;
        }
    }
    return ans;
}
相关推荐
月挽清风2 小时前
代码随想录第十五天
数据结构·算法·leetcode
TracyCoder1234 小时前
LeetCode Hot100(34/100)——98. 验证二叉搜索树
算法·leetcode
We་ct6 小时前
LeetCode 56. 合并区间:区间重叠问题的核心解法与代码解析
前端·算法·leetcode·typescript
努力学算法的蒟蒻8 小时前
day79(2.7)——leetcode面试经典150
算法·leetcode·职场和发展
2401_841495649 小时前
【LeetCode刷题】二叉树的层序遍历
数据结构·python·算法·leetcode·二叉树··队列
2401_841495649 小时前
【LeetCode刷题】二叉树的直径
数据结构·python·算法·leetcode·二叉树··递归
我是咸鱼不闲呀9 小时前
力扣Hot100系列19(Java)——[动态规划]总结(上)(爬楼梯,杨辉三角,打家劫舍,完全平方数,零钱兑换)
java·leetcode·动态规划
铉铉这波能秀10 小时前
LeetCode Hot100数据结构背景知识之列表(List)Python2026新版
数据结构·leetcode·list
仟濹10 小时前
算法打卡 day1 (2026-02-06 周四) | 算法: DFS | 1_卡码网98 可达路径 | 2_力扣797_所有可能的路径
算法·leetcode·深度优先
YuTaoShao12 小时前
【LeetCode 每日一题】1653. 使字符串平衡的最少删除次数——(解法一)前后缀分解
算法·leetcode·职场和发展