重构字符串(767)

767. 重构字符串 - 力扣(LeetCode)

解法:

cpp 复制代码
class Solution {
public:
    string reorganizeString(string s)
    {
        string res;
        //因为1 <= s.length <= 500 , uint64_t 类型足够
        uint16_t n = s.size();
        if (n == 0) {
            return res;
        }
        unordered_map<char, uint16_t> m;
        for (auto c : s) {
            m[c] += 1;
        }

        vector<pair<char, uint16_t>> v(m.begin(), m.end());
        
        //构建最大堆
        auto compare_f = [](const pair<char, uint16_t> & i1,
                            const pair<char, uint16_t> & i2)
        {return i1.second < i2.second;};

        //按照key-value : letter-count,按照count构建最小堆
        priority_queue<pair<char, uint16_t>, std::vector<pair<char, uint16_t>>, decltype(compare_f)> q (v.begin(), v.end(), compare_f);
        auto & i = q.top();
        
        //如果一个letter,其counter大于一半以上,则肯定无法构建
        if ((((n & 1) == 1) && (i.second > n/2 + 1)) ||
                (((n & 1) == 0) && (i.second > n/2)))
        {
            return  res;
        }
        
        //贪心法,每次从优先队列里面取出count最大的元素
        while (!q.empty()) {
            auto  i = move(q.top());
            q.pop();
            if (res.size() > 0 && res.back() == i.first) {
                //如果letter相同,则再取出次多的
                auto j = move(q.top());
                q.pop();
                res += j.first;
                j.second -= 1;
                //如果letter count 大于0,则继续插回队列
                if (j.second > 0) {
                    q.push(j);
                }
            }
            res += i.first;
            i.second -= 1;
            //如果letter count 大于0,则继续插回队列
            if (i.second > 0) {
                q.push(i);
            }
        }
        
        return res;
    }
};

总结:时间复杂度O(N2logN),空间复杂度O(N),应用到了最小堆、贪心算法。

相关推荐
CoovallyAIHub36 分钟前
应对不平衡数据集:MixUp、CutMix与Focal Loss实战指南
深度学习·算法·计算机视觉
NAGNIP1 小时前
一文理解提示微调(Prefix Tuning/Prompt Tuning/P Tuning)
算法
薛定谔的算法1 小时前
深入探索 ES6 中的 Map 数据结构
前端·javascript·算法
CoovallyAIHub1 小时前
AI如何一眼看穿鱼群健康?看改进HRNet模型实现水下健康监测
深度学习·算法·计算机视觉
稳兽龙1 小时前
codeforces(1045)(div2)D. Sliding Tree
c++·算法··路径树
熙客2 小时前
树的常见算法及Java实现
算法
轴测君2 小时前
3 无重复字符的最长子串
数据结构·算法·leetcode
2501_924731113 小时前
智慧城市交通场景误检率↓78%!陌讯多模态融合算法实战解析
人工智能·算法·目标检测·视觉检测·智慧城市
PAK向日葵6 小时前
【算法导论】XHS 0824 笔试题解
算法·面试
2501_924534897 小时前
智慧零售商品识别误报率↓74%!陌讯多模态融合算法在自助结算场景的落地优化
大数据·人工智能·算法·计算机视觉·目标跟踪·视觉检测·零售