Search⌘ K
AI Features

Solution: Palindrome Pairs

Explore an efficient solution to the palindrome pairs problem by using a Trie to store reversed words. Understand how to identify palindrome pairs through three main cases involving word reversals and prefix or suffix palindromes, enabling you to solve the problem efficiently with clear algorithmic steps.

Statement

You are given a 0-indexed array of unique strings called words.

A palindrome pair is defined as a pair of indexes (i, j) where both i and j are within the valid range of the list of words (that is, 00 \leq i, j << words.length), and i is not equal to j. The key condition is that when the word at index i is concatenated with the word at index j (forming words[i] + words[j]), the resulting string must be a palindrome.

Your task is to return all valid palindrome pairs as a list of index pairs.

Additionally, your solution must have a time complexity of O(sum ofO(\text{sum of} words.length)).

Constraints:

  • 11 \leq words.length 1000\leq 1000

  • ...