【力扣刷题】Leetcode 2592 最大化数组的伟大值

文章目录

      • [1. Leetcode 2592 最大化数组的伟大值](#1. Leetcode 2592 最大化数组的伟大值)

1. Leetcode 2592 最大化数组的伟大值

  • 题目链接

  • 本题思考的关键点:

    ① nums 的最小值要参与匹配,否则更大的数字更难匹配上;

    ② nums 最小值要与次小值进行比较,这样才能贡献值最大;

  • 用双指针的思想解题
    ① 双指针的模板

  • 本题双指针代码如下:

cpp 复制代码
	int cnt = 0;
    for (int i = 0, j = 0; j < n; i ++)
    {
        while (j < n && nums[i] == nums[j])  j ++;

        if (j >= n) break;

        if (nums[j] > nums[i])
        {
            cnt ++;
            j ++;
        }
    }
  • 上面这段双指针的代码简化如下:

    优化抓住的条件:1. 从大的数据进行枚举,因为从题目可得知,最小值一定要参匹配;

cpp 复制代码
    int cnt = 0;
    for (int i = 0; i < nums.size(); i ++)
        if (nums[cnt] < nums[i])
            cnt ++;
  • 二分的思想解题
    ② 双指针的模板
  • 本题二分答案代码如下:
cpp 复制代码
class Solution {
public:

    int maximizeGreatness(vector<int>& nums) {

    sort(nums.begin(), nums.end());  

    // 二分答案
    int l = 0, r = nums.size();
    while (l < r)
    {
        int mid = (l + r + 1) / 2;

        if (check(nums, mid))
            l = mid;
        else 
            r = mid - 1;
    }
    return l;
}

    bool check(vector<int>& nums, int k)
    {
        int n = nums.size();

        for (int i = 0; i < k; i ++)
            if (nums[i] >= nums[n - k + i])
                return false;

        return true;
    }
};
相关推荐
沙威玛_LHE15 小时前
树和二叉树
数据结构·算法
py有趣16 小时前
LeetCode算法学习之两数之和 II - 输入有序数组
学习·算法·leetcode
夏鹏今天学习了吗16 小时前
【LeetCode热题100(62/100)】搜索二维矩阵
算法·leetcode·矩阵
吃着火锅x唱着歌18 小时前
LeetCode 1128.等价多米诺骨牌对的数量
算法·leetcode·职场和发展
十八岁讨厌编程19 小时前
【算法训练营 · 补充】LeetCode Hot100(中)
算法·leetcode
橘颂TA19 小时前
【剑斩OFFER】算法的暴力美学——最小覆盖字串
算法·c/c++·就业
wearegogog12319 小时前
基于混合蛙跳算法和漏桶算法的无线传感器网络拥塞控制与分簇新方法
网络·算法
Tiandaren20 小时前
大模型应用03 || 函数调用 Function Calling || 概念、思想、流程
人工智能·算法·microsoft·数据分析
2301_7951672020 小时前
玩转Rust高级应用 如何进行理解Refutability(可反驳性): 模式是否会匹配失效
开发语言·算法·rust
小当家.10521 小时前
[LeetCode]Hot100系列.贪心总结+思想总结
算法·leetcode·职场和发展