当前位置: 首页 > article >正文

重构字符串(767)

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

解法:

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),应用到了最小堆、贪心算法。


http://www.kler.cn/a/522974.html

相关文章:

  • JMeter插件 Arrivals Thread Group 源码解析:实现原理与性能测试中的应用
  • mysql DDL可重入讨论
  • Ubuntu二进制部署K8S 1.29.2
  • 【deepseek】deepseek-r1本地部署-第二步:huggingface.co替换为hf-mirror.com国内镜像
  • 大模型GUI系列论文阅读 DAY4续:《Large Language Model Agent for Fake News Detection》
  • 李沐vscode配置+github管理+FFmpeg视频搬运+百度API添加翻译字幕
  • 【stm32学习】STM32F103相关特性
  • 抖音上线打车服务?抖音要大规模杀入网约车了吗?
  • Redis存储③Redis基本命令+内部编号和架构
  • SpringCloud系列教程:微服务的未来(十八)雪崩问题、服务保护方案、Sentinel快速入门
  • 接口技术-第3次作业
  • 供应链系统设计-供应链中台系统设计(九)- 商品中心设计篇
  • DBO优化最近邻分类预测matlab
  • c语言初级的复习
  • 2025牛客寒假算法营3
  • leetcode刷题-贪心03
  • 磁盘调度算法
  • 【PySide6快速入门】 QRadioButton单选按钮
  • 全程Kali linux---CTFshow misc入门
  • Python-基于PyQt5,json和playsound的通用闹钟
  • 汉语向编程指南
  • LeetCode:62.不同路径
  • 开发者交流平台项目部署到阿里云服务器教程
  • 【Redis】hash 类型的介绍和常用命令
  • 编解码技术:最大秩距离码(Maximum Rank Distance Code)
  • 代码随想录刷题day18|(哈希表篇)01.两数之和