DEV Community

Cover image for Longest palindromic substring in s
chandra penugonda
chandra penugonda

Posted on • Edited on

Longest palindromic substring in s

This problem was asked by Uber.

You are given a string s, find the longest palindromic substring in s. You may assume that the maximum length of s is 1000.

Example

function longestPalindrome(s) {

}

console.log(longestPalindrome('babad')); // bab
console.log(longestPalindrome('cbbd')); // bb
Enter fullscreen mode Exit fullscreen mode

Solution

function longestPalindrome(s) {
  let longest = "";
  for (let i = 0; i < s.length; i++) {
    const oddStr = expandFromMiddle(s, i, i);
    if (oddStr.length > longest.length) {
      longest = oddStr;
    }

    const evenStr = expandFromMiddle(s, i, i + 1);
    if (evenStr.length > longest.length) {
      longest = evenStr;
    }
  }

  function expandFromMiddle(str, left, right) {
    while (left >= 0 && right < str.length && s[left] === s[right]) {
      left--;
      right++;
    }
    return str.slice(left + 1, right);
  }
  return longest;
}
Enter fullscreen mode Exit fullscreen mode

Explanation

  • Iterate through each character in the string
  • For each character, expand outwards to find odd and even length palindromes centered at that character
  • Use a helper function to expand from the middle, incrementing left and right pointers until reaching different characters
  • Keep track of the longest palindrome seen so far
  • After checking all characters, return the longest palindrome

Image of Wix Studio

2025: Your year to build apps that sell

Dive into hands-on resources and actionable strategies designed to help you build and sell apps on the Wix App Market.

Get started

Top comments (0)

👋 Kindness is contagious

Immerse yourself in a wealth of knowledge with this piece, supported by the inclusive DEV Community—every developer, no matter where they are in their journey, is invited to contribute to our collective wisdom.

A simple “thank you” goes a long way—express your gratitude below in the comments!

Gathering insights enriches our journey on DEV and fortifies our community ties. Did you find this article valuable? Taking a moment to thank the author can have a significant impact.

Okay