1930. Unique Length-3 Palindromic Subsequences
Difficulty: Medium
Topics: Hash Table, String, Bit Manipulation, Prefix Sum
Given a string s, return the number of unique palindromes of length three that are a subsequence of s.
Note that even if there are multiple ways to obtain the same subsequence, it is still only counted once.
A palindrome is a string that reads the same forwards and backwards.
A subsequence of a string is a new string generated from the original string with some characters (can be none) deleted without changing the relative order of the remaining characters.
Example 1:
Example 2:
Example 3:
Constraints:
Hint:
Solution:
We can use an efficient algorithm that leverages prefix and suffix character tracking to count all valid palindromic subsequences.
Track Prefix Characters:
Use an array to store the set of characters encountered to the left of each position in the string. This will help in efficiently checking if a character can form the first part of a palindromic subsequence.
Track Suffix Characters:
Use another array to store the set of characters encountered to the right of each position in the string. This will help in efficiently checking if a character can form the third part of a palindromic subsequence.
Count Palindromic Subsequences:
For each character in the string, consider it as the middle character of a length-3 palindrome. Check for all valid combinations of prefix and suffix characters to determine unique palindromes.
Store Results:
Use a hash set to store unique palindromic subsequences, ensuring no duplicates.
Let's implement this solution in PHP: 1930. Unique Length-3 Palindromic Subsequences
Explanation:
Prefix Array:
- For each character at position i, prefix[i] stores all distinct characters encountered before index i.
Suffix Array:
- For each character at position i, suffix[i] stores all distinct characters encountered after index i.
Middle Character:
- Consider each character as the middle of the palindrome. For each combination of prefix and suffix characters that matches the middle character, form a length-3 palindrome.
Hash Map:
- Use an associative array ($uniquePalindromes) to store unique palindromes, ensuring duplicates are not counted.
Complexity
Time Complexity: O(n)
Space Complexity: O(n)
The code produces the correct results for the given examples:
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:
The above is the detailed content of Unique Length-alindromic Subsequences. For more information, please follow other related articles on the PHP Chinese website!