Leetcode2216. 美化数组的最少删除数

Every day a Leetcode

题目来源:2216. 美化数组的最少删除数

解法1:模拟

使用变量 count 代表已删除的元素个数,由于每次删除元素,剩余元素都会往前移动,因此当前下标为 i - count。

遍历一次数组 nums,若当前下标为偶数,且与下一位置元素相同,那么当前元素需被删除,令 count 自增。

最终数组长度为 n - count,若长度为奇数,需要再额外删除结尾元素(count 再加一),否则 count 即为答案。

代码:

c 复制代码
/*
 * @lc app=leetcode.cn id=2216 lang=cpp
 *
 * [2216] 美化数组的最少删除数
 */

// @lc code=start
class Solution
{
public:
    int minDeletion(vector<int> &nums)
    {
        int n = nums.size();
        int count = 0;
        for (int i = 0; i < n - 1; i++)
            if ((i - count) % 2 == 0 && nums[i] == nums[i + 1])
                count++;
        return (n - count) % 2 == 0 ? count : count + 1;
    }
};
// @lc code=end

结果:

复杂度分析:

时间复杂度:O(n),其中 n 是数组 nums 的长度。

空间复杂度:O(1)。

解法2:贪心

根据题目描述,我们知道,一个美丽数组有偶数个元素,且如果我们把这个数组中每相邻两个元素划分为一组,那么每一组中的两个元素都不相等。这意味着,组内的元素不能重复,但组与组之间的元素可以重复。

因此,我们考虑从左到右遍历数组,只要遇到相邻两个元素相等,我们就将其中的一个元素删除,即删除数加一;否则,我们可以保留这两个元素。

最后,我们判断删除后的数组长度是否为偶数,如果不是,则说明我们需要再删除一个元素,使得最终的数组长度为偶数。

代码:

c 复制代码
class Solution
{
public:
    int minDeletion(vector<int> &nums)
    {
        int n = nums.size();
        int ans = 0;
        for (int i = 0; i < n - 1; i++)
        {
            if (nums[i] == nums[i + 1])
                ans++;
            else
                i++;
        }
        ans += (n - ans) % 2;
        return ans;
    }
};

结果:

复杂度分析:

时间复杂度:O(n),其中 n 是数组 nums 的长度。

空间复杂度:O(1)。

相关推荐
AI迅剑2 分钟前
模块三:现代C++工程实践(4篇)第二篇《性能调优:Profile驱动优化与汇编级分析》
汇编·c++
凌肖战5 分钟前
力扣网编程135题:分发糖果(贪心算法)
算法·leetcode
Tony沈哲1 小时前
OpenCV 图像调色优化实录:从 forEach 到并行 + LUT 提速之路
opencv·算法
遇见尚硅谷1 小时前
C语言:20250714笔记
c语言·开发语言·数据结构·笔记·算法
byte轻骑兵1 小时前
【Bluedroid】蓝牙协议栈enable流程深度解析
android·c++·bluedroid
Norvyn_72 小时前
LeetCode|Day11|557. 反转字符串中的单词 III|Python刷题笔记
笔记·python·leetcode
chao_7892 小时前
动态规划题解_零钱兑换【LeetCode】
python·算法·leetcode·动态规划
吃着火锅x唱着歌2 小时前
LeetCode 424.替换后的最长重复字符
linux·算法·leetcode
hans汉斯2 小时前
【计算机科学与应用】面向APT攻击调查的溯源图冗余结构压缩
网络·算法·安全·web安全·yolo·目标检测·图搜索算法
Maybyy2 小时前
力扣454.四数相加Ⅱ
java·算法·leetcode