【Py/Java/C++三种语言详解】LeetCode每日一题240113【贪心】LeetCode2182、构建限制重复的字符串

文章目录

  • 题目链接
  • 题目描述
  • 解题思路
  • 代码
    • Python
    • Java
    • C++
    • 时空复杂度
  • 华为OD算法/大厂面试高频题算法练习冲刺训练

题目链接

LeetCode2182、构建限制重复的字符串

题目描述

给你一个字符串 s 和一个整数 repeatLimit ,用 s 中的字符构造一个新字符串 repeatLimitedString ,使任何字母 连续 出现的次数都不超过 repeatLimit 次。你不必使用 s 中的全部字符。

返回 字典序最大的 repeatLimitedString

如果在字符串 ab 不同的第一个位置,字符串 a 中的字母在字母表中出现时间比字符串 b 对应的字母晚,则认为字符串 a 比字符串 b 字典序更大 。如果字符串中前 min(a.length, b.length) 个字符都相同,那么较长的字符串字典序更大。

示例 1

输入:s = “cczazcc”, repeatLimit = 3
输出:“zzcccac”
解释:使用 s 中的所有字符来构造 repeatLimitedString “zzcccac”。 字母 ‘a’ 连续出现至多 1 次。 字母 ‘c’ 连续出现至多 3 次。 字母 ‘z’ 连续出现至多 2 次。 因此,没有字母连续出现超过 repeatLimit 次,字符串是一个有效的 repeatLimitedString 。 该字符串是字典序最大的 repeatLimitedString ,所以返回 “zzcccac” 。 注意,尽管 “zzcccca” 字典序更大,但字母 ‘c’ 连续出现超过 3 次,所以它不是一个有效的 repeatLimitedString 。

示例 2

输入:s = “aababab”, repeatLimit = 2
输出:“bbabaa”
解释: 使用 s 中的一些字符来构造 repeatLimitedString “bbabaa”。 字母 ‘a’ 连续出现至多 2 次。 字母 ‘b’ 连续出现至多 2 次。 因此,没有字母连续出现超过 repeatLimit 次,字符串是一个有效的 repeatLimitedString 。 该字符串是字典序最大的 repeatLimitedString ,所以返回 “bbabaa” 。 注意,尽管 “bbabaaa” 字典序更大,但字母 ‘a’ 连续出现超过 2 次,所以它不是一个有效的 repeatLimitedString 。

提示

  • 1 <= repeatLimit <= s.length <= 10(5)
  • s 由小写英文字母组成

解题思路

为了使得构建的字符串ans字典序尽可能大,贪心地采取以下策略:

  • 优先考虑剩余字符中最大的字符ch,若
    • ch剩余个数ch_num小于等于repeatLimit,则将这ch_numch都加入ans末尾
    • ch剩余个数ch_num大于repeatLimit,则将repeatLimitch加入ans末尾,接下来必须再插入一个第二大的字符在ans末尾

字符的个数很容易想到用哈希表计数器进行统计。

由于总是要考虑最大的字符或次大的字符,而且一旦最大字符用完,在后续构建中都不能再考虑,很容易想到使用栈来维护上述过程。将细节处理好即可。

代码

Python

# 贪心+栈:O(N/repeatLimit)
class Solution:def repeatLimitedString(self, s: str, repeatLimit: int) -> str:# 统计s中每个元素的个数并按照字典序进行排序stack = sorted([k, v] for k, v in Counter(s).items())ans = str()while len(stack) > 0:# 考虑剩余最大字符chch, ch_num = stack.pop()# 如果ch的个数小于重复限制if ch_num <= repeatLimit:# 则将其全部加在末尾                ans += ch * ch_num# 否则else:# 添加repeatLimit个ch在末尾ans += ch * repeatLimit # 如果此时还有其他字符存在,# 则添加一个次大字符if len(stack) > 0:# 次大字符的个数-1stack[-1][1] -= 1# 在ans末尾添加1个次大字符ans += stack[-1][0]# 若次大字符的个数降为0,则也需要删除if stack[-1][1] == 0:stack.pop()# 如果此时栈中已经没有其他字符# 说明后面也无法再进行添加,直接退出else:break# 将删除了repeatLimit个后的ch重新加入栈顶stack.append([ch, ch_num - repeatLimit])return ans

Java

class Solution {public String repeatLimitedString(String s, int repeatLimit) {Map<Character, Integer> charCount = new HashMap<>();List<Map.Entry<Character, Integer>> stack = new ArrayList<>();for (char ch : s.toCharArray()) {charCount.put(ch, charCount.getOrDefault(ch, 0) + 1);}for (Map.Entry<Character, Integer> entry : charCount.entrySet()) {stack.add(entry);}stack.sort(Comparator.comparing(Map.Entry::getKey));StringBuilder ans = new StringBuilder();while (!stack.isEmpty()) {char ch = stack.get(stack.size() - 1).getKey();int chNum = stack.get(stack.size() - 1).getValue();stack.remove(stack.size() - 1);if (chNum <= repeatLimit) {ans.append(String.valueOf(ch).repeat(chNum));} else {ans.append(String.valueOf(ch).repeat(repeatLimit));if (!stack.isEmpty()) {stack.get(stack.size() - 1).setValue(stack.get(stack.size() - 1).getValue() - 1);ans.append(stack.get(stack.size() - 1).getKey());if (stack.get(stack.size() - 1).getValue() == 0) {stack.remove(stack.size() - 1);}} else {break;}stack.add(Map.entry(ch, chNum - repeatLimit));}}return ans.toString();}
}

C++

class Solution {
public:string repeatLimitedString(string s, int repeatLimit) {unordered_map<char, int> charCount;vector<pair<char, int>> stack;for (char ch : s) {charCount[ch]++;}for (const auto& entry : charCount) {stack.push_back({entry.first, entry.second});}sort(stack.begin(), stack.end());string ans;while (!stack.empty()) {char ch = stack.back().first;int chNum = stack.back().second;stack.pop_back();if (chNum <= repeatLimit) {ans += string(chNum, ch);} else {ans += string(repeatLimit, ch);if (!stack.empty()) {stack.back().second--;ans += stack.back().first;if (stack.back().second == 0) {stack.pop_back();}} else {break;}stack.push_back({ch, chNum - repeatLimit});}}return ans;}
};

时空复杂度

时间复杂度:O(N/repeatLimit)。循环大致需要进行N/repeatLimit次。

空间复杂度:O(1)。栈所占空间,最大为26,可视为常数级别空间。


华为OD算法/大厂面试高频题算法练习冲刺训练

  • 华为OD算法/大厂面试高频题算法冲刺训练目前开始常态化报名!目前已服务100+同学成功上岸!

  • 课程讲师为全网50w+粉丝编程博主@吴师兄学算法 以及小红书头部编程博主@闭着眼睛学数理化

  • 每期人数维持在20人内,保证能够最大限度地满足到每一个同学的需求,达到和1v1同样的学习效果!

  • 60+天陪伴式学习,40+直播课时,300+动画图解视频,300+LeetCode经典题,200+华为OD真题/大厂真题,还有简历修改、模拟面试、专属HR对接将为你解锁

  • 可上全网独家的欧弟OJ系统练习华子OD、大厂真题

  • 可查看链接 大厂真题汇总 & OD真题汇总(持续更新)

  • 绿色聊天软件戳 od1336了解更多

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/620262.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

(南京观海微电子)——色温介绍

色温是表示光线中包含颜色成分的一个计量单位。从理论上说&#xff0c;黑体温度指绝对黑体从绝对零度&#xff08;&#xff0d;273℃&#xff09;开始加温后所呈现的颜色。黑体在受热后&#xff0c;逐渐由黑变红&#xff0c;转黄&#xff0c;发白&#xff0c;最后发出蓝色光。当…

im6ull学习总结(三-五)freetype显示正行字

知识补充 笛卡尔坐标系 这里笛卡尔坐标系就是初高中学的直角坐标系的第一象限 lcd坐标系则不同 这两个坐标系如何转换 观察两个坐标系 点&#xff08;x,y&#xff09;的x坐标在两个坐标系中相同&#xff0c;纵坐标&#xff08;y&#xff09;存在着yV-yV V是整个屏幕的行数的像…

MYSQL的操作

1.库的操作 1.1创建数据库 语法&#xff1a; CREATE DATABASE [IF NOT EXISTS] db_name [create_specification [, create_specification] ...] create_specification: [DEFAULT] CHARACTER SET charset_name [DEFAULT] COLLATE collation_name 说明&#xff1a; #…

python flask学生管理系统

预览 前端 jquery css html bootstrap: 4.x 后端 python: 3.6.x flask: 2.0.x 数据库 mysql: 5.7 学生管理模块 登录、退出查看个人信息、修改个人信息成绩查询查看已选课程选课、取消选课搜索课程课程列表分页功能 教师模块 登录、退出查看个人信息、修改个人信息录入…

leetcode 每日一题 2024年01月14日 删除排序链表中的重复元素

题目 83. 删除排序链表中的重复元素 给定一个已排序的链表的头 head &#xff0c; 删除所有重复的元素&#xff0c;使每个元素只出现一次 。返回 已排序的链表 。 示例 1&#xff1a; 输入&#xff1a;head [1,1,2] 输出&#xff1a;[1,2]示例 2&#xff1a; 输入&#xff…

解决Unexpected record signature 0X9maven 资源过滤

解决Unexpected record signature: 0X9|maven 资源过滤 记录问题&#xff1a;我们有个需求是根据excel模版导出一个excel表。我们的项目是SpringBoot&#xff0c;所以理所当然的把这个模版文件放到了&#xff0c;resources文件夹中。但是在导出文件的时候却遇到了invalid code …

二极管限幅电路理论分析,工作原理+作用

一、限幅是什么意思&#xff1f; 限幅也就是&#xff0c;将电压限制在某个范围内&#xff0c;去除交流信号的一部分但不会对波形的剩余部分造成影响。通常来说&#xff0c;限幅电路主要是由二极管构成&#xff0c;波形的形状取决于电路的配置和设计。二、限幅电路工作原…

场效应管在电路中如何控制电流大小

场效应管的概念 场效应晶体管&#xff08;FieldEffectTransistor缩写&#xff08;FET&#xff09;&#xff09;简称场效应管。主要有两种类型&#xff08;juncTIonFET—JFET&#xff09;和金属-氧化物半导体场效应管&#xff08;metal-oxidesemiconductorFET&#xff0c;简称M…

9.5.1 函数模板特化

函数模板 有了泛化版本比较函数&#xff0c;我们可以比较两个整数&#xff0c;两个字符&#xff0c;两个指针 6~10行&#xff0c;是一个函数模板 13~16行&#xff0c;都可以得到正常结果 22行&#xff0c;得到的结果是&#xff0c;"A001" < "A000", …

【k8s】Kubernetes 声明式 API、命令式

1. 资源管理方式&#xff1a; 1>. 命令式对象管理∶直接使用命令去操作kubernetes资源 kubectl run nginx-pod --imagenginx:1.17.1 --port802>. 命令式对象配置∶通过命令配置和配置文件去操作kubernetes资源 kubectl create/patch -f nginx-pod.yaml3>. 声明式对…

【OpenGauss源码学习 —— 执行器(execMain)】

执行器&#xff08;execMain&#xff09; 概述文件内容作用执行的操作主要函数概述 部分函数详细分析ExecutorStart 函数standard_ExecutorStart 函数 ExecutorRun 函数standard_ExecutorRun 函数 ExecutorFinish 函数standard_ExecutorFinish 函数 ExecutorEnd 函数standard_E…

京东宣布启动鸿蒙原生应用开发,全力支持鸿蒙生态 | 百能云芯

华为常务董事、终端BG CEO、智能汽车解决方案BU董事长余承东于1月10日在微博上发布了一条令人振奋的消息&#xff1a;京东即将启动鸿蒙原生应用的开发。这一消息在科技圈掀起了不小的波澜&#xff0c;也为鸿蒙系统的发展注入了新的动力。 京东集团首席执行官兼执行董事许冉和余…

SpringBoot读取配置文件中的内容

文章目录 1. 读取配置文件application.yml中内容的方法1.1 Environment1.2 Value注解1.3 ConfigurationProperties 注解1.4 PropertySources 注解&#xff0c;获取自定义配置文件中的内容&#xff0c;yml文件需要自行实现适配器1.5 YamlPropertiesFactoryBean 加载 YAML 文件1.…

集成开发环境(IDE)介绍

集成开发环境&#xff08;IDE&#xff09;介绍 集成开发环境&#xff08;Integrated Development Environment&#xff0c;IDE&#xff09;是一种软件应用程序&#xff0c;用于开发和编写软件。常见的IDE包括Eclipse、Visual Studio、IntelliJ IDEA、Qt Creator等。 集成开发环…

xcode-docC

docC(documentaion compiler) docC分为三种类型&#xff1a;articles,tutorials articles 文章介绍类型 tutorials 教程 讲解api的使用流程 苹果官方视频

SpringBoot知识03

1、多模块项目无法启动&#xff0c;报错Failed to execute goal on project*: Could not resolve dependencies for project

强化学习应用(七):基于Q-learning的无人机物流路径规划研究(提供Python代码)

一、Q-learning简介 Q-learning是一种强化学习算法&#xff0c;用于解决基于马尔可夫决策过程&#xff08;MDP&#xff09;的问题。它通过学习一个价值函数来指导智能体在环境中做出决策&#xff0c;以最大化累积奖励。 Q-learning算法的核心思想是通过不断更新一个称为Q值的…

软件外包资源网站分享

经济不景气导致很多人失业&#xff0c;能否找到一份工作或找些项目做做&#xff0c;这里列了一些国内和国外的资源网上&#xff0c;希望对大家有益&#xff1a; 国内篇&#xff1a; 软件项目交易网&#xff1a;(软件项目交易网)这是一个专注于软件开发需求的外包平台&#xf…

【DP】712. 两个字符串的最小ASCII删除和

题目 与583. 两个字符串的删除操作题目几乎一模一样&#xff01; 法1&#xff1a;DP class Solution {public int minimumDeleteSum(String s1, String s2) {int m s1.length() 1, n s2.length() 1;int[][] dp new int[m][n];for (int i 1; i < n; i) { // 首行dp[0…

Python如何免费调用微软Bing翻译API

一、引言 现在免费的机器翻译越来越少了&#xff0c;随着有道翻译开始收费&#xff0c;百度降低用户的免费机器翻译额度(目前只有实名认证过的高级用户才能获得100万字符的免费翻译额度)&#xff0c;而亚马逊、腾讯等机器翻译调用相对比较麻烦&#xff0c;需要下载各种插件包&…