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

相关推荐
Future_yzx1 小时前
算法基础学习——快排与归并(附带java模版)
学习·算法·排序算法
思逻辑维3 小时前
强大到工业层面的软件
数据结构·sql·sqlite·json
所以遗憾是什么呢?3 小时前
【题解】Codeforces Round 996 C.The Trail D.Scarecrow
数据结构·算法·贪心算法
qystca4 小时前
【16届蓝桥杯寒假刷题营】第2期DAY4
数据结构·c++·算法·蓝桥杯·哈希
JNU freshman4 小时前
线段树 算法
算法·蓝桥杯
英国翰思教育4 小时前
留学毕业论文如何利用不同问题设计问卷
人工智能·深度学习·学习·算法·学习方法·论文笔记
人类群星闪耀时5 小时前
寻找两个正序数组的中位数:分治法与二分查找的结合
算法·leetcode
এ旧栎5 小时前
蓝桥与力扣刷题(240 搜索二维矩阵||)
算法·leetcode·矩阵·学习方法
Xzh04235 小时前
c语言网 1127 尼科彻斯定理
数据结构·c++·算法
gentle_ice6 小时前
leetcode——删除链表的倒数第N个节点(java)
java·leetcode·链表