791. Custom Sort String
All prompts are owned by LeetCode. To view the prompt, click the title link above.
First completed : July 10, 2024
Last updated : July 10, 2024
Related Topics : Hash Table, String, Sorting
Acceptance Rate : 70.871 %
class Solution {
public String customSortString(String order, String s) {
HashMap<Character, Integer> reference = new HashMap<>();
for (int i = 0; i < order.length(); i++) {
reference.put(order.charAt(i), i);
}
Character[] output = new Character[s.length()];
for (int i = 0; i < s.length(); i++) {
output[i] = s.charAt(i);
}
Arrays.sort(output, (a, b) -> reference.getOrDefault(a, Integer.MAX_VALUE) - reference.getOrDefault(b, Integer.MAX_VALUE));
StringBuilder sb = new StringBuilder();
for (char c : output) {
sb.append(c);
}
return sb.toString();
}
}
class Solution {
public String customSortString(String order, String s) {
int[] charCounter = new int[26];
for (char c : s.toCharArray()) {
charCounter[c - 'a']++;
}
StringBuilder sb = new StringBuilder();
for (char c : order.toCharArray()) {
for (int i = 0; i < charCounter[c - 'a']; i++) {
sb.append(c);
}
charCounter[c - 'a'] = 0;
}
for (int i = 0; i < charCounter.length; i++) {
while (charCounter[i] > 0) {
sb.append((char) ('a' + i));
charCounter[i]--;
}
}
return sb.toString();
}
}