力扣767.重构字符串

力扣767.重构字符串

  • 将每个字母的出现次数存在哈希表中

    • 按出现次数排序
    • 如果最大的次数 > 其他次数之和 + 1,说明最终一定不会有合法答案
    • 从最大次数开始 先放偶数下标 再放奇数下标
cpp 复制代码
  class Solution {
  public:
      string reorganizeString(string s) {
          int n = s.size();
          unordered_map<char,int> cnt;
          for(char c:s)
              cnt[c] ++;
          
          vector<pair<char,int>> a(cnt.begin(),cnt.end());
         	//语法 自定义按次数排序
          ranges::sort(a,[](const auto&p,const auto&q)
          {
              return p.second > q.second;
          });
          int m = a[0].second;
          if(m > n - m + 1)
              return "";
          
          string res(n,0);
          int i = 0;
          for(auto [ch,cur] : a)
          {
              while(cur -- )
              {
                  res[i] = ch;
                  i += 2;
                  if(i >= n)
                      i = 1;
              }
          }
          return res;
      }
  };
相关推荐
董董灿是个攻城狮1 小时前
5分钟搞懂什么是窗口注意力?
算法
Dann Hiroaki1 小时前
笔记分享: 哈尔滨工业大学CS31002编译原理——02. 语法分析
笔记·算法
qqxhb3 小时前
零基础数据结构与算法——第四章:基础算法-排序(上)
java·数据结构·算法·冒泡·插入·选择
FirstFrost --sy4 小时前
数据结构之二叉树
c语言·数据结构·c++·算法·链表·深度优先·广度优先
森焱森4 小时前
垂起固定翼无人机介绍
c语言·单片机·算法·架构·无人机
搂鱼1145145 小时前
(倍增)洛谷 P1613 跑路/P4155 国旗计划
算法
Yingye Zhu(HPXXZYY)5 小时前
Codeforces 2021 C Those Who Are With Us
数据结构·c++·算法
无聊的小坏坏6 小时前
三种方法详解最长回文子串问题
c++·算法·回文串
长路 ㅤ   6 小时前
Java后端技术博客汇总文档
分布式·算法·技术分享·编程学习·java后端
秋说7 小时前
【PTA数据结构 | C语言版】两枚硬币
c语言·数据结构·算法