3016. Minimum Number of Pushes to Type Word II
Medium
Topics : Hash Table
, String
, Greedy
, Sorting
, Counting
You are given a string word
containing lowercase English letters.
Telephone keypads have keys mapped with distinct collections of lowercase English letters, which can be used to form words by pushing them. For example, the key 2
is mapped with ["a","b","c"]
, we need to push the key one time to type "a"
, two times to type "b"
, and three times to type "c"
.
It is allowed to remap the keys numbered 2
to 9
to distinct collections of letters. The keys can be remapped to any amount of letters, but each letter must be mapped to exactly one key. You need to find the minimum number of times the keys will be pushed to type the string word
.
Return the minimum number of pushes needed to type word
after remapping the keys.
An example mapping of letters to keys on a telephone keypad is given below. Note that 1
, *
, #
, and 0
do not map to any letters.
Example 1:
- Input: word = "abcde"
- Output: 5
-
Explanation: The remapped keypad given in the image provides the minimum cost.
- "a" -> one push on key 2
- "b" -> one push on key 3
- "c" -> one push on key 4
- "d" -> one push on key 5
- "e" -> one push on key 6
- Total cost is 1 + 1 + 1 + 1 + 1 = 5.
- It can be shown that no other mapping can provide a lower cost.
Example 2:
- Input: word = "xyzxyzxyzxyz"
- Output: 12
-
Explanation: The remapped keypad given in the image provides the minimum cost.
- "x" -> one push on key 2
- "y" -> one push on key 3
- "z" -> one push on key 4
- Total cost is 1 * 4 + 1 * 4 + 1 * 4 = 12
- It can be shown that no other mapping can provide a lower cost.
- Note that the key 9 is not mapped to any letter: it is not necessary to map letters to every key, but to map all the letters.
Example 3:
- Input: word = "aabbccddeeffgghhiiiiii"
- Output: 24
-
Explanation: The remapped keypad given in the image provides the minimum cost.
- "a" -> one push on key 2
- "b" -> one push on key 3
- "c" -> one push on key 4
- "d" -> one push on key 5
- "e" -> one push on key 6
- "f" -> one push on key 7
- "g" -> one push on key 8
- "h" -> two pushes on key 9
- "i" -> one push on key 9
- Total cost is 1 * 2 + 1 * 2 + 1 * 2 + 1 * 2 + 1 * 2 + 1 * 2 + 1 * 2 + 2 * 2 + 6 * 1 = 24.
- It can be shown that no other mapping can provide a lower cost.
Constraints:
1 <= word.length <= 105
-
word
consists of lowercase English letters.
Hint:
- We have 8 keys in total. We can type 8 characters with one push each, 8 different characters with two pushes each, and so on.
- The optimal way is to map letters to keys evenly.
- Sort the letters by frequencies in the word in non-increasing order.
Solution:
To solve this problem, we can follow these steps:
- Count the Frequency of Each Character: Determine how often each character appears in the input word.
- Sort the Characters by Frequency: Sort these characters in descending order based on their frequency.
- Assign Characters to Keys: Allocate the characters to keys (2-9) such that the most frequent characters are assigned to the keys requiring the fewest pushes.
Step-by-Step Implementation in PHP
-
Count the Frequency of Each Character:
- Use an associative array to store the frequency of each character.
-
Sort the Characters by Frequency:
- Sort the characters based on their frequency in descending order.
-
Assign Characters to Keys:
- Iterate through the sorted characters and assign them to keys. The first 8 characters get 1 push each, the next 8 characters get 2 pushes each, and so on.
Let's implement this solution in PHP: 3016. Minimum Number of Pushes to Type Word II
<?php
// Test cases
echo minimumPushes("abcde") . "\n"; // Output: 5
echo minimumPushes("xyzxyzxyzxyz") . "\n"; // Output: 12
echo minimumPushes("aabbccddeeffgghhiiiiii") . "\n"; // Output: 24
?>
Explanation:
-
Counting Frequencies:
- We iterate through the word and count the occurrences of each character using an associative array
$frequency
.
- We iterate through the word and count the occurrences of each character using an associative array
-
Sorting by Frequency:
- We use
arsort
to sort the associative array$frequency
by its values in descending order.
- We use
-
Calculating Pushes:
- We initialize
$pushes
to zero and iterate over the sorted frequency array. - The number of pushes required for each character is calculated based on its position in the sorted array. Characters at positions 0-7 require 1 push, positions 8-15 require 2 pushes, and so on.
- We incrementally calculate the total number of pushes required to type the word.
- We initialize
This approach ensures that the most frequent characters are assigned to the keys that require the fewest pushes, thereby minimizing the total number of pushes needed.
Contact Links
If you found this series helpful, please consider giving the repository a star on GitHub or sharing the post on your favorite social networks š. Your support would mean a lot to me!
If you want more helpful content like this, feel free to follow me:
Top comments (0)