惯性聚合 高效追踪和阅读你感兴趣的博客、新闻、科技资讯
阅读原文 在惯性聚合中打开

推荐订阅源

aimingoo的专栏
aimingoo的专栏
量子位
freeCodeCamp Programming Tutorials: Python, JavaScript, Git & More
S
Schneier on Security
Cisco Talos Blog
Cisco Talos Blog
T
ThreatConnect
J
Java Code Geeks
博客园 - 司徒正美
A
Arctic Wolf
T
True Tiger Recordings
C
Cybersecurity and Infrastructure Security Agency CISA
Cyberwarzone
Cyberwarzone
Know Your Adversary
Know Your Adversary
T
Threat Research - Cisco Blogs
V
Vulnerabilities – Threatpost
Recorded Future
Recorded Future
P
Palo Alto Networks Blog
The Hacker News
The Hacker News
The Register - Security
The Register - Security
S
Securelist
www.infosecurity-magazine.com
www.infosecurity-magazine.com
C
CXSECURITY Database RSS Feed - CXSecurity.com
Application and Cybersecurity Blog
Application and Cybersecurity Blog
I
Intezer
P
Privacy & Cybersecurity Law Blog
Scott Helme
Scott Helme
K
Kaspersky official blog
博客园 - 聂微东
Last Week in AI
Last Week in AI
V
V2EX
小众软件
小众软件
F
Fox-IT International blog
Martin Fowler
Martin Fowler
Apple Machine Learning Research
Apple Machine Learning Research
T
Tenable Blog
F
Future of Privacy Forum
Microsoft Security Blog
Microsoft Security Blog
让小产品的独立变现更简单 - ezindie.com
让小产品的独立变现更简单 - ezindie.com
腾讯CDC
Stack Overflow Blog
Stack Overflow Blog
C
Check Point Blog
阮一峰的网络日志
阮一峰的网络日志
GbyAI
GbyAI
T
Threatpost
I
InfoQ
P
Proofpoint News Feed
CTFtime.org: upcoming CTF events
CTFtime.org: upcoming CTF events
T
Tor Project blog
G
GRAHAM CLULEY
D
DataBreaches.Net

DEV Community

HTB — MonitorsFour | Writeup Fr 97. Embeddings and Vector Search: Semantic Search That Works Deep Dive: Building "Gravity Paint" - A Tactile Physics Instrument with React, Matter.js, and p5.js ABAP Unit Testing with Test Doubles and Mocking Frameworks: A Senior Architects Guide to Isolating Dependencies in SAP S/4HANA kovax-react 0.8: Tailwind v4 preset, FormField adapters, ColorModeScript, and Storybook I built an AI résumé tool that refuses to lie about your experience The hat Azure Entra ID User & Role Management — Step-by-Step Practical Guide With A Simple Excercise The AI-Native Company: How a Single Founder Can Build Global Organizations Powered by AWS and an Ecosystem of Artificial Intelligences Building a Lightweight Remote MCP Knowledge Base on Cloudflare Workers Why I built Trinavo for the MENA merchants Western platforms ignore The N+1 Query That Killed Our Database, And How I Fixed It Docstrings vs Markdown Docs: What Should Developers Actually Write? Training Data Provenance: The Manifest Diff That Explains the Hash Add SVGIcons MCP to Claude Code and Find SVG Icons from Your Terminal 3 CLI Tools You Can Buy with Crypto — No KYC, No Subscriptions COSS Weekly: OpenClaw competitor NanoClaw Raises $12M, Dust Raises $40M, Sonar Acquires Gitar, and more How to know if you actually need mobile proxies (without buying any) Building Cursor for Community: A Buildathon Built on Time Pressure How we built a PII masking layer for LLM APIs — local detection, reversible tokens, one line to integrate Why MLFQ Was Way Ahead of Its Time Add Runtime Limits to Claude Agent Workflows I Built a Prompt Injection Detector with 98% Recall on Unseen Attacks. Here's Why Data Beat Architecture. 8 Vite Config Options Every Developer Should Know (Vite 8) Feature Flags That Forgot to Leave Why Trust Infrastructure Is Becoming the Hidden Layer of Donation Platforms XyPriss: Rethinking Core Performance and Zero-Trust Architecture in Modern Backends Designing Configuration for Scalable Treasure Hunts SSH Login Delays: The 10-Second Wait That Drives Us Crazy Building Production Multi-Agent Workflows in n8n: What 50 Deployments Taught Us A 3-layer memory system that gives Claude Code persistent context across sessions. Trishul SNMP Suite 2.0.1: Better MIBs, Traps, and SNMP Labs How I built a production AI SaaS as a solo developer Auto-labelling 1.2M robotics frames with VLMs: a failover story India’s Laws Were Not Built for AI — And Courts Are Filling the Gap skill-insp: A Skill That Scores Other Skills Clprolf Minimalist Messaging in the Age of AI What's actually in a good .cursorrules file? I built 10 of them — here's what I learned Building Strong Python Basics – Loops, Functions and Logic How to Choose the Right Tech Stack for Your Project I built a free multi-tab JSON editor — here's what I learned HTTP Headers Every Developer Should Know (2026) Building Cross-Platform Digital Products: Challenges and Best Practices Data Privacy in the Age of AI: How Product Teams Can Build Trust with Users What Would WordPress Look Like If It Were Designed Today? Why Backup Success Does Not Mean Database Recoverability Local AI Office Assistant That Never Sends Your Documents to the Cloud Building TaskForge: Translating Enterprise Chaos into an Open-Source Scheduler Tesla P40 in a Homelab: 24GB of Inference on a Budget Llama 4: Meta's Latest — Scout, Maverick, and the MoE Revolution George Hotz called AI code 'slop.' He's half right. Como Construir um Fluxo de Trabalho Baseado em Engenharia de Prompt e Automação We Audited Our Agent Tool-Call Traces. Half Our Eval Data Was Garbage. The Hidden Cost of Downtime: How SRE Error Budgets Protect National Economic Infrastructure Getting started with openHUMANS can be an exciting venture for developers looking to create innovative applications in the realm of human-ce Stack Overflow: A Powerful Community for Developers and Learners From Language Models to Humanoid Minds ✨ Road to Senior #2: How Computers Think in Numbers Why LLM debugging fails on fragmented repository context How to Deploy a LangGraph Agent on AWS Bedrock AgentCore An outreach kit for solo founders whose drafts can't hallucinate Open Satchel is live Amy Kwalwasser and the Growing Importance of Quantum Risk Modeling I Built ShellReq - A Native API Client for VS Code & Terminal If Microsoft and Uber can't afford AI coding, what chance do the rest of us have? MADCAP: Building a Multi-Agent Debate CLI That Argues With Itself So You Don't Have To Why most AI fails at IDOR (and how AMAS fixes it with causal reasoning) How to Audit a Laravel Codebase You've Inherited LangGraph 워크플로우 템플릿 (v34) BugBench: a developer origin story and practical guide for VS Code / Kiro users A solution to messy token systems for Next.js A NestJS reference app that proves the nest-native stack under realistic backend pressure Observability for AI Systems: Monitoring Drift, Hallucinations, and Reliability in Production I Thought “Data Analyst” Was the Whole Game… Then I Entered the Data Avengers Office 👀 Create and configure network security groups How to analyze the cost of Kafka? How I Shipped 2,500+ Commits With AI Agents Using a 12-Phase Workflow [Boost] We built MDCMS, a Markdown-first CMS for teams using AI agents Zero Heap Allocations at 1.18 GB/s: Deep Dive into ForgeZero 4.0.x The Minimum Viable Test Suite for Working with Agents Why Perplexity Started Citing My Blog: 5 Changes That Actually Worked Sync Supabase via OAuth: No Connection String Needed I asked three AI models the same API question. Only one had it right. Implementing Saga Pattern With Lambda Durable Function Why does AI forget what you said (and how to fix it) I built a daily Wordle-style game for AI tools - Here's how Mapping Polish company structures: querying KRS direct via API Built tmpdrop — a tiny self-hosted ephemeral file drop Running Local LLM - 0$ Personal Agentic AI Assistant - Part 3 LLD Object-Oriented Design: Interfaces & Abstract Classes (Designing Contracts) The Smaller Ship: Vitalik, the Ethereum Foundation's Restructuring, and What It Leaves for Investors Looking for 4 people to build something weird with me Building a Local-Only RAG System with Ollama and TypeScript The False Positive Tax: a 1:1 TP:FP analysis of eslint-plugin-security What's new in Data Preprocessor 1.5.x — R codegen, Robust Scaler, and a deadlock post-mortem How I self-hosted my Flask app on an old laptop for almost free I built a free DSA interview prep site because I was tired of the existing options I built an AI agent that migrates Next.js Pages Router to App Router
LeetCode Solution: 5. Longest Palindromic Substring
Aryan Subudh · 2026-05-26 · via DEV Community

Aryan Subudhi

5. Longest Palindromic Substring: Unraveling the Palindromic Puzzle 🧩

Hey fellow coders! 👋 Today, we're diving into a LeetCode classic that often stumps beginners but reveals a really elegant pattern once you spot it: the Longest Palindromic Substring problem.

Don't let the fancy name scare you! We'll break it down piece by piece, find an intuitive way to tackle it, and emerge victorious with a neat, efficient solution. Ready? Let's go!

📜 Problem Explanation

The problem asks us to find the longest palindromic substring within a given string s.

"Whoa, hold on!" you might say. "What's a palindrome? And what's a substring?" Great questions!

  • Palindrome: A string that reads the same forwards and backward. Think words like "madam", "racecar", or even single letters like "a".
  • Substring: A contiguous sequence of characters within a string. For "babad", "bab", "aba", "bad", "a" are all substrings. "bba" is not a substring because the 'b's aren't contiguous in that order.

So, our mission is to scan through the given string s, find all possible substrings that are also palindromes, and then return the longest one among them.

Let's look at the examples:

  • Example 1: s = "babad"
    • Possible palindromic substrings: "b", "a", "b", "a", "d", "bab", "aba".
    • The longest ones are "bab" and "aba". Either is a valid answer.
  • Example 2: s = "cbbd"
    • Possible palindromic substrings: "c", "b", "b", "d", "bb".
    • The longest is "bb".

Constraints:

  • The string s will have between 1 and 1000 characters.
  • It will only contain digits and English letters. No weird symbols to worry about!

🤔 Intuition: Don't Brute Force, Explore From the Middle!

A common first thought for many string problems is: "Let's check every possible substring!"

If you have a string of length N:

  1. There are N * (N + 1) / 2 possible substrings (e.g., for "abc", "a", "b", "c", "ab", "bc", "abc").
  2. For each substring, checking if it's a palindrome takes O(length_of_substring) time.
  3. This quickly leads to an O(N^3) solution, which for N=1000 is 1000^3 = 1,000,000,000 operations – way too slow! 🐌

We need something smarter.

What makes a palindrome special? It's symmetrical around its center!

Consider "racecar":
r a c e c a r
The e is the center. Everything expands outwards equally.

Consider "abba":
a b b a
The "center" is between the two bs.

This gives us a huge hint! Instead of picking two ends and checking inwards, what if we pick a center and expand outwards?

Every palindrome has a center:

  • Odd-length palindromes: A single character is the center (e.g., 'a' in "bab", 'e' in "racecar").
  • Even-length palindromes: The "center" is the space between two identical characters (e.g., the space between the two 'b's in "bb", or "abba").

This means we can iterate through every possible "center" in our string and try to expand outwards to find the longest palindrome centered there. Since there are N characters and N-1 spaces between characters, there are roughly 2N - 1 potential centers.

🚀 Approach: Expand Around Center

Our intuition leads us to a solid plan:

  1. We'll maintain variables start and max_len to keep track of the beginning index and length of the longest palindrome we've found so far. Initialize start = 0 and max_len = 1 (a single character is always a palindrome).
  2. We'll iterate through each character in the string s using an index i. For each i, we consider it as a potential center for a palindrome.
  3. Since palindromes can be odd or even length, we'll need to check two types of expansions for each i:
    • Odd length: i itself is the center. We'll try to expand outwards from left = i, right = i.
    • Even length: The space after i is the center. We'll try to expand outwards from left = i, right = i + 1.
  4. To avoid repeating code, we'll create a helper function, let's call it expandAroundCenter(s, left, right). This function will take the string s and two pointers, left and right, and expand them outwards as long as:
    • left is not less than 0 (we're within string bounds).
    • right is not greater than or equal to len(s) (we're within string bounds).
    • s[left] is equal to s[right] (the characters match, so it's still a palindrome).
    • Once these conditions are no longer met, the function returns the length of the palindrome found (which is right - left - 1).
  5. In our main loop, after calling expandAroundCenter for both odd and even cases, we'll compare the lengths of the palindromes found. If either is longer than our current max_len, we update max_len and calculate the new start index. The start index will be i - (current_palindrome_length - 1) // 2. (This formula looks tricky, but it simply finds the leftmost character of the new longest palindrome given its length and its "center" i).
  6. After checking all possible centers, we return the substring s[start : start + max_len].

Let's trace s = "babad":

  • Initialize start = 0, max_len = 1 (our initial "b")
  • i = 0 (char 'b')
    • expandAroundCenter(s, 0, 0) -> returns length 1 ("b")
    • expandAroundCenter(s, 0, 1) -> 'b' != 'a', returns length 0
  • i = 1 (char 'a')
    • expandAroundCenter(s, 1, 1) -> returns length 1 ("a")
    • expandAroundCenter(s, 1, 2) -> 'a' == 'b' NO, returns length 0
    • expandAroundCenter(s, 0, 2) for center 'a': s[0]=='b', s[2]=='b'. left becomes -1, right becomes 3. Palindrome is "bab", length 3.
      • max_len = 3, start = 1 - (3-1)//2 = 1 - 1 = 0. Current best: "bab".
  • i = 2 (char 'b')
    • expandAroundCenter(s, 2, 2) -> returns length 1 ("b")
    • expandAroundCenter(s, 2, 3) -> 'b' != 'a', returns length 0
    • expandAroundCenter(s, 1, 3) for center 'b': s[1]=='a', s[3]=='a'. left becomes 0, right becomes 4. Palindrome is "aba", length 3.
      • Length is 3, same as current max_len. We don't need to update start and max_len if it's not strictly greater, but it's fine if we do (it would become "aba"). Let's say it updates to "aba".
  • ... and so on.

Finally, we return s[start : start + max_len].

💻 Code

class Solution:
    def longestPalindrome(self, s: str) -> str:
        if not s:
            return ""

        # Helper function to expand around a center
        # It takes the string s, and the left and right pointers
        # It expands outwards as long as characters match and stay within bounds
        # Returns the length of the palindrome found
        def expandAroundCenter(left: int, right: int) -> int:
            while left >= 0 and right < len(s) and s[left] == s[right]:
                left -= 1
                right += 1
            # After the loop, left and right are one step *past* the palindrome
            # So, the length is (right - 1) - (left + 1) + 1 = right - left - 1
            return right - left - 1

        start_index = 0  # Stores the starting index of the longest palindrome
        max_length = 0   # Stores the maximum length found so far

        # Loop through each character to consider it as a center
        for i in range(len(s)):
            # Case 1: Odd length palindrome (e.g., "aba", "racecar")
            # The current character s[i] is the center
            len1 = expandAroundCenter(i, i)

            # Case 2: Even length palindrome (e.g., "abba", "bb")
            # The center is between s[i] and s[i+1]
            len2 = expandAroundCenter(i, i + 1)

            # Get the maximum length found from these two expansions
            current_max_len = max(len1, len2)

            # If this palindrome is longer than our current max_length
            if current_max_len > max_length:
                max_length = current_max_len
                # Calculate the new starting index for this longest palindrome
                # For an odd length palindrome, start = i - (length - 1) / 2
                # For an even length palindrome, start = i - (length / 2 - 1)
                # Both can be generalized as: i - (length - 1) // 2
                start_index = i - (max_length - 1) // 2

        # Return the substring from start_index with max_length
        return s[start_index : start_index + max_length]

Enter fullscreen mode Exit fullscreen mode

⏱️ Time & Space Complexity Analysis

Let's break down how efficient our solution is:

  • Time Complexity: O(N^2)

    • The main for loop iterates N times (once for each character in s).
    • Inside the loop, we call expandAroundCenter twice.
    • The expandAroundCenter function, in the worst case (e.g., s = "aaaaa"), might expand all the way to the boundaries of the string. This takes O(N) time.
    • Therefore, the total time complexity is N * O(N) = O(N^2).
    • Given N <= 1000, N^2 is 1,000,000, which is perfectly acceptable within typical time limits (usually around 10^8 operations per second).
  • Space Complexity: O(1)

    • We are only using a few constant variables (start_index, max_length, i, len1, len2, left, right). We are not storing any data structures that grow with the input size N.
    • The slicing s[start_index : start_index + max_length] creates a new string, but this is part of the output, not auxiliary space used by the algorithm itself.

🌟 Key Takeaways

  1. Don't Jump to Brute Force: Always consider the constraints and think about whether a naive O(N^3) or O(N^2) approach will pass. Often, there's a more elegant pattern waiting to be discovered!
  2. Palindromes and Symmetry: The core idea for many palindrome problems revolves around their symmetrical nature. Thinking about "centers" is a powerful paradigm.
  3. Odd vs. Even Length: Remember that palindromes can have either odd or even lengths, and your solution needs to account for both types of "centers."
  4. Helper Functions: Breaking down complex logic into smaller, reusable helper functions (like expandAroundCenter) makes your code cleaner, more readable, and easier to debug.
  5. Smallest Palindrome is 1: Don't forget that a single character is always a palindrome, which can be useful for initializing max_length.

This problem is a fantastic introduction to dynamic programming and string algorithms, and mastering the "expand around center" technique will serve you well in many other coding challenges!

Happy coding! ✨


Submission Details

  • Author Account: aryan-subudhi
  • Publishing Time: 2026-05-25 23:24:13