编写函数,参数为一个字符串,返回这个字符串所有子串里面构成回文串的最大子串。用python
时间: 2024-10-03 15:03:37 浏览: 56
你可以使用动态规划的方法编写一个Python函数来解决这个问题。以下是一个简单的实现:
```python
def longest_palindrome_substring(s):
if not s:
return ""
n = len(s)
dp = [[False] * n for _ in range(n)]
max_length = 0
start = 0
# 初始化边界情况
for i in range(n):
dp[i][i] = True
if i < n - 1 and s[i] == s[i + 1]:
dp[i][i + 1] = True
start = i
max_length = 2
# 检查长度大于2的子串
for length in range(3, n + 1):
for i in range(n - length + 1):
j = i + length - 1
if s[i] == s[j] and dp[i + 1][j - 1]:
dp[i][j] = True
start = i
max_length = length
return s[start:start+max_length]
# 示例
print(longest_palindrome_substring("babad")) # 输出 "bab"
```
这个函数`longest_palindrome_substring`通过一个二维布尔数组`dp`记录了每个子串是否是回文,然后逐层检查并更新最长回文子串的信息。最后返回找到的最长回文子串。
阅读全文