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

相关推荐
IT大白鼠14 小时前
AIGC性能的关键瓶颈:算力、数据、算法三者如何互相制约?
算法·aigc
白雪茫茫14 小时前
监督学习、半监督学习、无监督学习算法详解
python·学习·算法·ai
FengyunSky14 小时前
浅析 空间频率响应 SFR 计算
算法
树下水月15 小时前
PHP 一种改良版的雪花算法
算法·php·dreamweaver
一只数据集15 小时前
全尺寸人形机器人灵巧手力觉触觉数据集-2908条ROSbag数据覆盖14大应用场景深度解析
大数据·人工智能·算法·机器人
罗西的思考16 小时前
【GUI-Agent】阿里通义MAI-UI 代码阅读(2)--- 实现
人工智能·算法·机器学习
流年如夢16 小时前
单链表进阶版 -->双向链表
数据结构·链表
刀法如飞18 小时前
TypeScript 数组去重的 20 种实现方式,哪一种你还不知道?
前端·javascript·算法
流年如夢18 小时前
单链表 -->增、删、查、改等详细操作
c语言·数据结构
sali-tec18 小时前
C# 基于OpenCv的视觉工作流-章66-直线夹角
图像处理·人工智能·opencv·算法·计算机视觉