g2101_2200.s2182_construct_string_with_repeat_limit.Solution Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of leetcode-in-java21 Show documentation
Show all versions of leetcode-in-java21 Show documentation
Java-based LeetCode algorithm problem solutions, regularly updated
package g2101_2200.s2182_construct_string_with_repeat_limit;
// #Medium #String #Greedy #Heap_Priority_Queue #Counting
// #2022_06_07_Time_26_ms_(96.11%)_Space_63.6_MB_(62.78%)
/**
* 2182 - Construct String With Repeat Limit\.
*
* Medium
*
* You are given a string `s` and an integer `repeatLimit`. Construct a new string `repeatLimitedString` using the characters of `s` such that no letter appears **more than** `repeatLimit` times **in a row**. You do **not** have to use all characters from `s`.
*
* Return _the **lexicographically largest**_ `repeatLimitedString` _possible_.
*
* A string `a` is **lexicographically larger** than a string `b` if in the first position where `a` and `b` differ, string `a` has a letter that appears later in the alphabet than the corresponding letter in `b`. If the first `min(a.length, b.length)` characters do not differ, then the longer string is the lexicographically larger one.
*
* **Example 1:**
*
* **Input:** s = "cczazcc", repeatLimit = 3
*
* **Output:** "zzcccac"
*
* **Explanation:** We use all of the characters from s to construct the repeatLimitedString "zzcccac".
*
* The letter 'a' appears at most 1 time in a row.
*
* The letter 'c' appears at most 3 times in a row.
*
* The letter 'z' appears at most 2 times in a row.
*
* Hence, no letter appears more than repeatLimit times in a row and the string is a valid repeatLimitedString.
*
* The string is the lexicographically largest repeatLimitedString possible so we return "zzcccac".
*
* Note that the string "zzcccca" is lexicographically larger but the letter 'c' appears more than 3 times in a row, so it is not a valid repeatLimitedString.
*
* **Example 2:**
*
* **Input:** s = "aababab", repeatLimit = 2
*
* **Output:** "bbabaa"
*
* **Explanation:** We use only some of the characters from s to construct the repeatLimitedString "bbabaa".
*
* The letter 'a' appears at most 2 times in a row. The letter 'b' appears at most 2 times in a row.
*
* Hence, no letter appears more than repeatLimit times in a row and the string is a valid repeatLimitedString.
*
* The string is the lexicographically largest repeatLimitedString possible so we return "bbabaa".
*
* Note that the string "bbabaaa" is lexicographically larger but the letter 'a' appears more than 2 times in a row, so it is not a valid repeatLimitedString.
*
* **Constraints:**
*
* * 1 <= repeatLimit <= s.length <= 105
* * `s` consists of lowercase English letters.
**/
@SuppressWarnings("java:S135")
public class Solution {
public String repeatLimitedString(String s, int repeatLimit) {
char[] result = new char[s.length()];
int[] freq = new int[128];
int index = 0;
for (char c : s.toCharArray()) {
freq[c]++;
}
char max = 'z';
char second = 'y';
while (true) {
while (max >= 'a' && freq[max] == 0) {
max--;
}
if (max < 'a') {
break;
}
second = (char) Math.min(max - 1, second);
int count = Math.min(freq[max], repeatLimit);
freq[max] -= count;
while (count-- > 0) {
result[index++] = max;
}
if (freq[max] == 0) {
max = second--;
continue;
}
while (second >= 'a' && freq[second] == 0) {
second--;
}
if (second < 'a') {
break;
}
result[index++] = second;
freq[second]--;
}
return new String(result, 0, index);
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy