重构字符串(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),应用到了最小堆、贪心算法。

相关推荐
聚客AI1 天前
🙋‍♀️Transformer训练与推理全流程:从输入处理到输出生成
人工智能·算法·llm
大怪v1 天前
前端:人工智能?我也会啊!来个花活,😎😎😎“自动驾驶”整起!
前端·javascript·算法
惯导马工1 天前
【论文导读】ORB-SLAM3:An Accurate Open-Source Library for Visual, Visual-Inertial and
深度学习·算法
骑自行车的码农1 天前
【React用到的一些算法】游标和栈
算法·react.js
博笙困了1 天前
AcWing学习——双指针算法
c++·算法
moonlifesudo1 天前
322:零钱兑换(三种方法)
算法
NAGNIP2 天前
大模型框架性能优化策略:延迟、吞吐量与成本权衡
算法
美团技术团队2 天前
LongCat-Flash:如何使用 SGLang 部署美团 Agentic 模型
人工智能·算法
Fanxt_Ja2 天前
【LeetCode】算法详解#15 ---环形链表II
数据结构·算法·leetcode·链表
侃侃_天下2 天前
最终的信号类
开发语言·c++·算法