【Leetcode】2182. 构造限制重复的字符串

文章目录

题目

2182. 构造限制重复的字符串

问题:给你一个字符串 s 和一个整数 repeatLimit ,用 s 中的字符构造一个新字符串 repeatLimitedString ,使任何字母 连续 出现的次数都不超过 repeatLimit 次。你不必使用 s 中的全部字符。
示例 1:
输入 :s = "cczazcc", repeatLimit = 3
输出 :"zzcccac"
解释

使用 s 中的所有字符来构造 repeatLimitedString "zzcccac"。

字母 'a' 连续出现至多 1 次。

字母 'c' 连续出现至多 3 次。

字母 'z' 连续出现至多 2 次。

因此,没有字母连续出现超过 repeatLimit 次,字符串是一个有效的 repeatLimitedString 。

该字符串是字典序最大的 repeatLimitedString ,所以返回 "zzcccac" 。

注意,尽管 "zzcccca" 字典序更大,但字母 'c' 连续出现超过 3 次,所以它不是一个有效的 repeatLimitedString 。

返回 字典序最大的 repeatLimitedString 。

如果在字符串 a 和 b 不同的第一个位置,字符串 a 中的字母在字母表中出现时间比字符串 b 对应的字母晚,则认为字符串 a 比字符串 b 字典序更大 。如果字符串中前 min(a.length, b.length) 个字符都相同,那么较长的字符串字典序更大。
示例 2
输入 :s = "aababab", repeatLimit = 2
输出 :"bbabaa"
解释

使用 s 中的一些字符来构造 repeatLimitedString "bbabaa"。

字母 'a' 连续出现至多 2 次。

字母 'b' 连续出现至多 2 次。

因此,没有字母连续出现超过 repeatLimit 次,字符串是一个有效的 repeatLimitedString 。

该字符串是字典序最大的 repeatLimitedString ,所以返回 "bbabaa" 。

注意,尽管 "bbabaaa" 字典序更大,但字母 'a' 连续出现超过 2 次,所以它不是一个有效的 repeatLimitedString 。

思路

这道题是一个简单的构造题,简单来说就是用题目给i出的字符串重新构造一个字典序最大的字符串。

记录所有字母的出现次数,然后我们从大的字母开始枚举。如果当前字母没用完就全加到答案中,否则就向前一个小的字母借一个,如果已经没有更加小的字符了则退出。

代码

c++ 复制代码
class Solution {
public:
    string repeatLimitedString(string s, int repeatLimit) {
       int cnt[26]={0};
       for(char &i:s)
           cnt[i-'a']++;    
       int num=0;
       string a;          
       int i=25;
       while(i>=0){
           while(i>=0&&!cnt[i]){i--;num=0;}
           if(i<0)break;
           if(num<repeatLimit){
               a+=(char)(i+'a');    
               cnt[i]--;        
               num++;
           }
           else{
               int j=i-1;
               if(j<0)break;
               while(j>=0&&!cnt[j]){j--;}
               if(j<0)break;
               else{
               a+=(char)(j+'a');
               cnt[j]--;
               num=0;                    
               }
           }
       }
       return a;
    }
};
相关推荐
乔宕一1 小时前
stm32 链接脚本没有 .gcc_except_table 段也能支持 C++ 异常
c++·stm32·嵌入式硬件
SuperCandyXu1 小时前
P3205 [HNOI2010] 合唱队-普及+/提高
c++·算法·洛谷
_OP_CHEN1 小时前
数据结构(C语言篇):(十二)实现顺序结构二叉树——堆
c语言·数据结构·算法·二叉树·学习笔记··顺序结构二叉树
_君落羽_1 小时前
ARM寄存器以及异常处理
c++
Yingjun Mo2 小时前
1. 统计推断-基于神经网络与Langevin扩散的自适应潜变量建模与优化
人工智能·神经网络·算法·机器学习·概率论
free2 小时前
基于librdkafa C++客户端生产者发送数据失败问题处理#2
c++·kafka
小柯J桑_3 小时前
Linux:线程封装
linux·运维·c++
地平线开发者3 小时前
征程 6 | 灰度图部署链路介绍
算法·自动驾驶
地平线开发者3 小时前
手撕大模型|KVCache 原理及代码解析
算法·自动驾驶
doll ~CJ4 小时前
基于QVTKOpenGLNativeWidget的三维点云可视化实现
c++·qt·软件开发·三维点云可视化