Skip to content

Commit 42be577

Browse files
solves #2287: Rearrange Characters to Make Target String in java
1 parent c9ec8a8 commit 42be577

File tree

2 files changed

+28
-1
lines changed

2 files changed

+28
-1
lines changed

README.md

Lines changed: 1 addition & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -738,7 +738,7 @@
738738
| 2273 | [Find Resultant Array After Removing Anagrams](https://leetcode.com/problems/find-resultant-array-after-removing-anagrams) | [![Java](assets/java.png)](src/FindResultantArrayAfterRemovingAnagrams.java) | |
739739
| 2278 | [Percentage of Letter in String](https://leetcode.com/problems/percentage-of-letter-in-string) | [![Java](assets/java.png)](src/PercentageOfLetterInString.java) | |
740740
| 2283 | [Check if Number Has Equal Digit Count and Digit Value](https://leetcode.com/problems/check-if-number-has-equal-digit-count-and-digit-value) | [![Java](assets/java.png)](src/CheckIfNumberHasEqualDigitCountAndDigitValue.java) | |
741-
| 2287 | [Rearrange Characters to Make Target String](https://leetcode.com/problems/rearrange-characters-to-make-target-string) | | |
741+
| 2287 | [Rearrange Characters to Make Target String](https://leetcode.com/problems/rearrange-characters-to-make-target-string) | [![Java](assets/java.png)](src/RearrangeCharactersToMakeTargetString.java) | |
742742
| 2293 | [Min Max Game](https://leetcode.com/problems/min-max-game) | | |
743743
| 2299 | [Strong Password Checker II](https://leetcode.com/problems/strong-password-checker-ii) | | |
744744
| 2300 | [Successful Pairs of Spells and Potions](https://leetcode.com/problems/successful-pairs-of-spells-and-potions) | [![Python](assets/python.png)](python/successfull_pairs_of_spells_and_potions.py) | |
Lines changed: 27 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,27 @@
1+
// https://leetcode.com/problems/rearrange-characters-to-make-target-string
2+
// T: O(|s| + |target|)
3+
// S: O(1)
4+
5+
import java.util.HashMap;
6+
import java.util.Map;
7+
8+
public class RearrangeCharactersToMakeTargetString {
9+
public int rearrangeCharacters(String s, String target) {
10+
final Map<Character, Integer> sCharFrequencies = getCharFrequencies(s);
11+
final Map<Character, Integer> targetCharFrequencies = getCharFrequencies(target);
12+
13+
int maxCopies = Integer.MAX_VALUE;
14+
for (char targetChar : targetCharFrequencies.keySet()) {
15+
maxCopies = Math.min(maxCopies, sCharFrequencies.getOrDefault(targetChar, 0) / targetCharFrequencies.get(targetChar));
16+
}
17+
return maxCopies;
18+
}
19+
20+
private Map<Character, Integer> getCharFrequencies(String string) {
21+
final Map<Character, Integer> result = new HashMap<>();
22+
for (int i = 0 ; i < string.length() ; i++) {
23+
result.put(string.charAt(i), result.getOrDefault(string.charAt(i), 0) + 1);
24+
}
25+
return result;
26+
}
27+
}

0 commit comments

Comments
 (0)