Search⌘ K
AI Features

Solution: Search Suggestions System

Explore how to build a search suggestions system using trie to efficiently suggest at most three products matching each prefix of a searched word. Understand the construction, searching mechanism, and time-space tradeoffs of trie vs naive approaches to optimize prefix-based recommendations.

Statement

Given an array of strings called products and a word to search, design a system that, when each character of the searched word is typed, suggests at most three product names from products. Suggested products should share a common prefix with the searched word. If more than three products exist with a common prefix, return the three product names that appear first in lexicographical order.

Return the suggested products, which will be a list of lists after each character of searched word is typed.

Constraints:

  • 11 \leq products.length 1000\leq 1000
  • 11 \leq products[i].length 3000\leq 3000
...