3541. Find Most Frequent Vowel and Consonant
Difficulty: Easy
Topics: Hash Table, String, Counting, Biweekly Contest 156
You are given a string s consisting of lowercase English letters ('a' to 'z').
Your task is to:
- Find the vowel (one of 'a','e','i','o', or'u') with the maximum frequency.
- Find the consonant (all other letters excluding vowels) with the maximum frequency.
Return the sum of the two frequencies.
Note: If multiple vowels or consonants have the same maximum frequency, you may choose any one of them. If there are no vowels or no consonants in the string, consider their frequency as 0.
The frequency of a letter x is the number of times it occurs in the string.
Example 1:
- Input: s = "successes"
- Output: 6
- 
Explanation:
- The vowels are: 'u'(frequency 1),'e'(frequency 2). The maximum frequency is 2.
- The consonants are: 's'(frequency 4),'c'(frequency 2). The maximum frequency is 4.
- The output is 2 + 4 = 6.
 
- The vowels are: 
Example 2:
- Input: s = "aeiaeia"
- Output: 3
- 
Explanation:
- The vowels are: 'a'(frequency 3),'e'( frequency 2),'i'(frequency 2). The maximum frequency is 3.
- There are no consonants in s. Hence, maximum consonant frequency = 0.
- The output is 3 + 0 = 3.
 
- The vowels are: 
Constraints:
- 1 <= s.length <= 100
- 
sconsists of lowercase English letters only.
Hint:
- Use a hashmap
- Simulate as described
Solution:
We need to find the sum of the maximum frequency of a vowel and the maximum frequency of a consonant in a given string. The solution involves counting the occurrences of each character, categorizing them as vowels or consonants, and then determining the highest frequency in each category.
Approach
- Define Vowels: Identify the vowels as 'a', 'e', 'i', 'o', and 'u'.
- Count Frequencies: Use an associative array to count how many times each character appears in the string.
- Separate Vowels and Consonants: Iterate through the frequency array, separating the counts into vowels and consonants.
- Find Maximum Frequencies: Determine the highest frequency among the vowels and the highest among the consonants. If there are no vowels or consonants, use 0 for the respective maximum.
- Return Sum: Add the two maximum frequencies and return the result.
Let's implement this solution in PHP: 3541. Find Most Frequent Vowel and Consonant
<?php
/**
 * @param String $s
 * @return Integer
 */
function maxFreqSum($s) {
    ...
    ...
    ...
    /**
     * go to ./solution.php
     */
}
// Test cases
echo maxFreqSum("successes") . "\n"; // Output: 6
echo maxFreqSum("aeiaeia") . "\n";   // Output: 3
echo maxFreqSum("zzz") . "\n";       // Output: 3
echo maxFreqSum("a") . "\n";         // Output: 1
?>
Explanation:
- 
Initialization: We start by defining the vowels and initializing an empty array $freqto store the frequency of each character.
- 
Frequency Counting: We iterate through each character in the string, updating the frequency count in the $freqarray.
- Finding Maximums: We then iterate through the frequency array. For each character, we check if it is a vowel. If it is, we compare its count to the current maximum vowel count. If it is a consonant, we compare its count to the current maximum consonant count.
- Result Calculation: Finally, we return the sum of the maximum vowel count and the maximum consonant count. If there are no vowels or consonants, the respective maximum will remain 0, which is handled naturally.
This approach efficiently categorizes and counts the characters, ensuring optimal performance even for the upper constraint of string length (100 characters). The solution is straightforward and leverages basic array operations to achieve the desired result.
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)