【LeetCode每日一题】2182. 构造限制重复的字符串

2024-01-14 01:52

本文主要是介绍【LeetCode每日一题】2182. 构造限制重复的字符串,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

2024-1-13

文章目录

      • [2182. 构造限制重复的字符串](https://leetcode.cn/problems/construct-string-with-repeat-limit/)
          • 思路:

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

在这里插入图片描述

思路:

按照字符出现次数从高到低的顺序进行重复,通过维护一个指针 j 来寻找下一个非零出现次数的字母。同时,利用 StringBuilder 对象可以高效地构建字符串,避免频繁的字符串拼接操作

  1. 首先,创建一个长度为26的数组 cnt,用于统计字符串 s 中每个字符出现的次数。数组的下标对应字母表中的字母,通过 s.charAt(i) - 'a' 可以得到字符在字母表中的位置,然后将对应位置的计数器加1。
  2. 创建一个 StringBuilder 对象 ans,用于构建最终结果。
  3. 从字母表的最后一个字母 ‘z’ 开始,依次处理每个字母。同时维护一个指针 j,初始值为当前字母的前一个字母下标 i-1
  4. 进入一个循环,直到当前字母的出现次数为0。在循环中,主要进行以下操作:
    • 将当前字母重复的次数与限制次数 repeatLimit 取较小值,设为变量 k。使用 for 循环遍历 k 次,将当前字母添加到 ans 中,并将字母的计数器减1。
    • 如果当前字母的出现次数为0,则跳出内部循环。
    • 在内部循环中,需要寻找下一个非零出现次数的字母,即从 j 开始向前搜索。如果找到了下一个字母(即 j >= 0 并且 cnt[j] != 0),则将其添加到 ans 中,并将该字母的计数器减1。
    • 如果找不到下一个字母,则跳出外部循环。
  5. 最终,返回 ans 构建的字符串作为结果。
    public String repeatLimitedString(String s, int repeatLimit) {// 创建一个长度为26的数组,用于统计字符串s中每个字符出现的次数int[] cnt = new int[26];for (int i = 0; i < s.length(); ++i) {++cnt[s.charAt(i) - 'a'];}// 创建一个StringBuilder对象,用于构建最终结果StringBuilder ans = new StringBuilder();// 遍历字母表,从后往前依次处理每个字母for (int i = 25, j = 24; i >= 0; --i) {// j表示当前字母的前一个字母下标,初始值为i-1j = Math.min(j, i - 1);// 循环直到当前字母的出现次数为0while (true) {// 将当前字母重复的次数与限制次数取较小值,进行遍历并添加到结果中for (int k = Math.min(cnt[i], repeatLimit); k > 0; --k) {ans.append((char) ('a' + i));--cnt[i];}// 如果当前字母的出现次数为0,则跳出循环if (cnt[i] == 0) {break;}// 寻找下一个非零出现次数的字母while (j >= 0 && cnt[j] == 0) {--j;}// 如果找不到下一个字母,则跳出循环if (j < 0) {break;}// 将下一个字母添加到结果中,并将其出现次数减1ans.append((char) ('a' + j));--cnt[j];}}// 返回最终结果return ans.toString();}

点击移步博客主页,欢迎光临~

偷cyk的图

这篇关于【LeetCode每日一题】2182. 构造限制重复的字符串的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/603544

相关文章

哈希leetcode-1

目录 1前言 2.例题  2.1两数之和 2.2判断是否互为字符重排 2.3存在重复元素1 2.4存在重复元素2 2.5字母异位词分组 1前言 哈希表主要是适合于快速查找某个元素(O(1)) 当我们要频繁的查找某个元素,第一哈希表O(1),第二,二分O(log n) 一般可以分为语言自带的容器哈希和用数组模拟的简易哈希。 最简单的比如数组模拟字符存储,只要开26个c

poj2406(连续重复子串)

题意:判断串s是不是str^n,求str的最大长度。 解题思路:kmp可解,后缀数组的倍增算法超时。next[i]表示在第i位匹配失败后,自动跳转到next[i],所以1到next[n]这个串 等于 n-next[n]+1到n这个串。 代码如下; #include<iostream>#include<algorithm>#include<stdio.h>#include<math.

poj3261(可重复k次的最长子串)

题意:可重复k次的最长子串 解题思路:求所有区间[x,x+k-1]中的最小值的最大值。求sa时间复杂度Nlog(N),求最值时间复杂度N*N,但实际复杂度很低。题目数据也比较水,不然估计过不了。 代码入下: #include<iostream>#include<algorithm>#include<stdio.h>#include<math.h>#include<cstring

poj 2135 有流量限制的最小费用最大流

题意: 农场里有n块地,其中约翰的家在1号地,二n号地有个很大的仓库。 农场有M条道路(双向),道路i连接着ai号地和bi号地,长度为ci。 约翰希望按照从家里出发,经过若干块地后到达仓库,然后再返回家中的顺序带朋友参观。 如果要求往返不能经过同一条路两次,求参观路线总长度的最小值。 解析: 如果只考虑去或者回的情况,问题只不过是无向图中两点之间的最短路问题。 但是现在要去要回

poj 3422 有流量限制的最小费用流 反用求最大 + 拆点

题意: 给一个n*n(50 * 50) 的数字迷宫,从左上点开始走,走到右下点。 每次只能往右移一格,或者往下移一格。 每个格子,第一次到达时可以获得格子对应的数字作为奖励,再次到达则没有奖励。 问走k次这个迷宫,最大能获得多少奖励。 解析: 拆点,拿样例来说明: 3 2 1 2 3 0 2 1 1 4 2 3*3的数字迷宫,走两次最大能获得多少奖励。 将每个点拆成两个

poj 2195 bfs+有流量限制的最小费用流

题意: 给一张n * m(100 * 100)的图,图中” . " 代表空地, “ M ” 代表人, “ H ” 代表家。 现在,要你安排每个人从他所在的地方移动到家里,每移动一格的消耗是1,求最小的消耗。 人可以移动到家的那一格但是不进去。 解析: 先用bfs搞出每个M与每个H的距离。 然后就是网络流的建图过程了,先抽象出源点s和汇点t。 令源点与每个人相连,容量为1,费用为

poj 3068 有流量限制的最小费用网络流

题意: m条有向边连接了n个仓库,每条边都有一定费用。 将两种危险品从0运到n-1,除了起点和终点外,危险品不能放在一起,也不能走相同的路径。 求最小的费用是多少。 解析: 抽象出一个源点s一个汇点t,源点与0相连,费用为0,容量为2。 汇点与n - 1相连,费用为0,容量为2。 每条边之间也相连,费用为每条边的费用,容量为1。 建图完毕之后,求一条流量为2的最小费用流就行了

pip-tools:打造可重复、可控的 Python 开发环境,解决依赖关系,让代码更稳定

在 Python 开发中,管理依赖关系是一项繁琐且容易出错的任务。手动更新依赖版本、处理冲突、确保一致性等等,都可能让开发者感到头疼。而 pip-tools 为开发者提供了一套稳定可靠的解决方案。 什么是 pip-tools? pip-tools 是一组命令行工具,旨在简化 Python 依赖关系的管理,确保项目环境的稳定性和可重复性。它主要包含两个核心工具:pip-compile 和 pip

leetcode-24Swap Nodes in Pairs

带头结点。 /*** Definition for singly-linked list.* public class ListNode {* int val;* ListNode next;* ListNode(int x) { val = x; }* }*/public class Solution {public ListNode swapPairs(L

leetcode-23Merge k Sorted Lists

带头结点。 /*** Definition for singly-linked list.* public class ListNode {* int val;* ListNode next;* ListNode(int x) { val = x; }* }*/public class Solution {public ListNode mergeKLists