Loading...
Loading...
Loading...
Loading...
Loading...
Loading...
Loading...
Loading...
Loading...
Loading...
Loading...
Loading...
Loading...
Loading...
Loading...
Loading...
Loading...
Loading...
Loading...
Loading...
Understanding Palindromes: Brute Force vs Expand Around Center Algorithms | Optimizing Time Complexity | n^3 vs n^2
 Feb 20, 2025 
    688 views 
 Written by Array Alchemist
 LeetCode wizard with 75 conquered challenges under my belt.
Turning algorithm nightmares into "Aha!" moments, one explanation at a time.
Join me to level up your coding skills – from interviews to real-world application! 
 
The algorithm discussed in this thread expand around center approach is a powerful technique that can solve a variety of problems related to palindromes and string manipulation. It’s also an important concept in real-world applications, especially in fields like data processing, bioinformatics, and text analysis. Let’s why?
📌 Google – Search, NLP, and Plagiarism Detection
Google needs to analyze millions of documents for plagiarism, text similarity, and search ranking.
✅ Where Expand Around Center is used?
Given a string s, return the longest substring of s that is a palindrome.
A palindrome is a string that reads the same forward and backward.
If there are multiple palindromic substrings that have the same length, return any one of them.
Example 1:
isPalindrome(word) { let l = 0, r = word.length - 1 while (l < r) { if (word[l] !== word[r]) { return false } l++ r-- } return true }longestPalindrome(s) { if (s.length === 1) { return s } let result = "" for (let i = 0; i < s.length; i++) { for (let j = i + 1; j <= s.length; j++) { let substring = s.substring(i, j) if (this.isPalindrome(substring)) { if (result.length < substring.length) { result = substring } } } } return result }Brute-Force Approach : How it works:
Why it’s inefficient:
Expand Around Center Approach
How it works:
Why it’s efficient:
Let's use the string s = "babad".
var longestPalindrome = function (s) { let start = 0 let maxLength = 1This function takes two indices, left and right, and expands outwards as long as the characters at these indices are the same and the indices are within the bounds of the string.
If the current substring length (right - left + 1) is greater than maxLength, it updates maxLength and start.
function expandAroundCenter(left, right) { while (0 <= left && right < s.length && s[left] === s[right]) { const current = right - left + 1 if (maxLength < current) { maxLength = current start = left } left-- right++ } }for (let i = 0; i < s.length; i++) { expandAroundCenter(i, i) expandAroundCenter(i, i + 1) } return s.substring(start, start + maxLength) };How this works?
i = 0 (character = 'b'): Left = 0, Right = 0 Expand: s[0] == s[0] → 'b' == 'b' → Palindrome ("b") Update maxLength = 1, start = 0 Expand further: Left = -1 (out of bounds) → Stopi = 1 (character = 'a'): Left = 1, Right = 1 Expand: s[1] == s[1] → 'a' == 'a' → Palindrome ("a") Update maxLength = 1, start = 1 Expand further: Left = 0, Right = 2 → s[0] == s[2] → 'b' == 'b' → Palindrome ("bab") Update maxLength = 3, start = 0 Expand further: Left = -1 (out of bounds) → Stopi = 2 (character = 'b'): Left = 2, Right = 2 Expand: s[2] == s[2] → 'b' == 'b' → Palindrome ("b") maxLength remains 3 Expand further: Left = 1, Right = 3 → s[1] == s[3] → 'a' == 'a' → Palindrome ("aba") Update maxLength = 3, start = 1 Expand further: Left = 0, Right = 4 → s[0] == s[4] → 'b' == 'd' → Not a palindrome → Stopi = 3 (character = 'a'): Left = 3, Right = 3 Expand: s[3] == s[3] → 'a' == 'a' → Palindrome ("a") maxLength remains 3 Expand further: Left = 2, Right = 4 → s[2] == s[4] → 'b' == 'd' → Not a palindrome → Stopi = 4 (character = 'd'): Left = 4, Right = 4 Expand: s[4] == s[4] → 'd' == 'd' → Palindrome ("d") maxLength remains 3 Expand further: Left = 3, Right = 5 (out of bounds) → StopAnother Example: s = "abba", (Even-Length):
Step 1: Initialize Variables
start = 0
maxLength = 1
Step 2: Loop Through the String
i = 1 (characters = 'b' and 'b'): Left = 1, Right = 2 Check if s[1] == s[2] → 'b' == 'b' → Palindrome ("bb") Update maxLength = 2, start = 1 Expand further: Left = 0, Right = 3 → s[0] == s[3] → 'a' == 'a' → Palindrome ("abba") Update maxLength = 4, start = 0 Expand further: Left = -1 (out of bounds) → StopUse the expand-around-center approach for finding the longest palindromic substring because it is more efficient and scales better for larger inputs. The brute-force approach is only useful for understanding the problem or for very small strings.
Other Problems This Approach Can Solve:
#palindrome #leetcode #expandAroundCenter