【贪心】个人练习-Leetcode-1647. Minimum Deletions to Make Character Frequencies Unique

题目链接:https://leetcode.cn/problems/minimum-deletions-to-make-character-frequencies-unique/description/

题目大意:给出一个字符串s,只包含小写字母。目标是【通过删除若干个字符】将其变为「每个字符出现的频次都不同」的字符串,求最小的删除字符数量。

思路:可以画一张柱状图,横坐标是出现频次,柱子的高度是这个出现频次的字符的个数。删除「n个」字符意味着将某根柱子高度-1,让其左边「n格」的柱子高度+1。最终目标是让所有柱子高度为1(但0频次可以有很多个,因为一个字符出现次数为0意味着删光了)。

很显然柱子的高度只能往左转移,那么从某根柱子开始向左找第一个高度为0的频次即可。不可能找不到,因为最终可以到达频次为0,也就是全删光。

用一个set记录高度大于1的柱子(频次,显然0除外),对它们进行贪心即可。

完整代码

cpp 复制代码
class Solution {
public:
    int minDeletions(string s) {
        int freq[100001] = {};
        int cnt[26] = {};

        for (auto c : s) {
            cnt[c-'a']++;
        }

        set<int> q;
        for (int i = 0; i < 26; i++) {
            if (cnt[i]) {
                freq[cnt[i]]++;
                if (freq[cnt[i]] > 1) {
                    q.insert(cnt[i]);
                }
            }
        }

        int ans = 0;
        for (auto it = q.begin(); it != q.end(); it++) {
            int idx = *it-1;
            while (freq[*it] > 1) {
                while (idx > 0 && freq[idx]) {
                    idx--;
                }
                freq[idx]++;
                freq[*it]--;
                ans += *it-idx;
            }
        }
        return ans;
    }
};
相关推荐
菜鸟江多多5 分钟前
32x32热成像高斯滤波图像处理
图像处理·单片机·算法
阳洞洞15 分钟前
二叉树的层序遍历
数据结构·算法·leetcode·二叉树遍历·广度优先搜索
今天也要早睡早起16 分钟前
代码随想录算法训练营Day32| 完全背包问题(二维数组 & 滚动数组)、LeetCode 518 零钱兑换 II、377 组合总数 IV、爬楼梯(进阶)
数据结构·c++·算法·leetcode·动态规划·完全背包
火车叼位1 小时前
初中生也能懂的贝叶斯定理:拆解一个改变世界的公式
人工智能·数学·算法
ChoSeitaku1 小时前
NO.66十六届蓝桥杯备战|基础算法-贪心-区间问题|凌乱的yyy|Rader Installation|Sunscreen|牛栏预定(C++)
c++·算法·蓝桥杯
用手码出世界1 小时前
二叉树——队列bfs专题
数据结构·算法·宽度优先
OneQ6661 小时前
C++自学笔记---指针在数组遍历中的应用
c++·笔记·算法
EnigmaCoder1 小时前
蓝桥杯刷题周计划(第四周)
c++·算法·蓝桥杯
绿水毛怪.1 小时前
蓝桥杯基础算法-字符串与集合
算法·职场和发展·蓝桥杯
悄悄敲敲敲2 小时前
C++第14届蓝桥杯b组学习笔记
c++·学习·算法·蓝桥杯