当前位置: 首页 > wzjs >正文

口碑好的句容网站建设正规seo排名公司

口碑好的句容网站建设,正规seo排名公司,如何做企业套模网站,三合一网站管理系统给你一个字符串s,找到s中最长的回文子串。 示例 1: 输入:s "babad" 输出:"bab" 解释:"aba" 同样是符合题意的答案。 示例 2: 输入:s "cbbd" 输…

给你一个字符串s,找到s中最长的回文子串。

示例 1:

输入:s = "babad"

输出:"bab"

解释:"aba" 同样是符合题意的答案。

示例 2:

输入:s = "cbbd"

输出:"bb"

提示:

1 <= s.length <= 1000

s 仅由数字和英文字母组成

方法一:动态规划

思路与算法

对于一个子串而言,如果它是回文串,并且长度大于 2,那么将它首尾的两个字母去除之后,它仍然是个回文串。例如对于字符串 “ababa”,如果我们已经知道 “bab” 是回文串,那么 “ababa” 一定是回文串,这是因为它的首尾两个字母都是 “a”。

根据这样的思路,我们就可以用动态规划的方法解决本题。我们用 P(i,j) 表示字符串 s 的第 i 到 j 个字母组成的串(下文表示成 s[i:j])是否为回文串:

P(i,j)={

true, 如果子串Si Sj是回文串

false, 其它情况

这里的「其它情况」包含两种可能性:

s[i,j] 本身不是一个回文串;

i>j,此时 s[i,j] 本身不合法。

那么我们就可以写出动态规划的状态转移方程:

P(i,j)=P(i+1,j−1)∧(S i = =S j)

也就是说,只有 s[i+1:j−1] 是回文串,并且 s 的第 i 和 j 个字母相同时,s[i:j] 才会是回文串。

上文的所有讨论是建立在子串长度大于 2 的前提之上的,我们还需要考虑动态规划中的边界条件,即子串的长度为 1 或 2。对于长度为 1 的子串,它显然是个回文串;对于长度为 2 的子串,只要它的两个字母相同,它就是一个回文串。因此我们就可以写出动态规划的边界条件:

P(i,i)=true

P(i,i+1)=(Si = =S i+1)

根据这个思路,我们就可以完成动态规划了,最终的答案即为所有 P(i,j)=true 中 j−i+1(即子串长度)的最大值。注意:在状态转移方程中,我们是从长度较短的字符串向长度较长的字符串进行转移的,因此一定要注意动态规划的循环顺序。

public class Solution {public String longestPalindrome(String s) {int len = s.length();if (len < 2) {return s;}int maxLen = 1;int begin = 0;// dp[i][j] 表示 s[i..j] 是否是回文串boolean[][] dp = new boolean[len][len];// 初始化:所有长度为 1 的子串都是回文串for (int i = 0; i < len; i++) {dp[i][i] = true;}char[] charArray = s.toCharArray();// 递推开始// 先枚举子串长度for (int L = 2; L <= len; L++) {// 枚举左边界,左边界的上限设置可以宽松一些for (int i = 0; i < len; i++) {// 由 L 和 i 可以确定右边界,即 j - i + 1 = L 得int j = L + i - 1;// 如果右边界越界,就可以退出当前循环if (j >= len) {break;}if (charArray[i] != charArray[j]) {dp[i][j] = false;} else {if (j - i < 3) {dp[i][j] = true;} else {dp[i][j] = dp[i + 1][j - 1];}}// 只要 dp[i][L] == true 成立,就表示子串 s[i..L] 是回文,此时记录回文长度和起始位置if (dp[i][j] && j - i + 1 > maxLen) {maxLen = j - i + 1;begin = i;}}}return s.substring(begin, begin + maxLen);}}

复杂度分析

时间复杂度:O(n2),其中 n 是字符串的长度。动态规划的状态总数为 O(n 2),对于每个状态,我们需要转移的时间为 O(1)。

空间复杂度:O(n2),即存储动态规划状态需要的空间。

精简写法

public String longestPalindrome(String s) {if (s == null || s.length() < 2) {return s;}int strLen = s.length();int maxStart = 0;  //最长回文串的起点int maxEnd = 0;    //最长回文串的终点int maxLen = 1;  //最长回文串的长度boolean[][] dp = new boolean[strLen][strLen];for (int r = 1; r < strLen; r++) {for (int l = 0; l < r; l++) {if (s.charAt(l) == s.charAt(r) && (r - l <= 2 || dp[l + 1][r - 1])) {dp[l][r] = true;if (r - l + 1 > maxLen) {maxLen = r - l + 1;maxStart = l;maxEnd = r;}}}}return s.substring(maxStart, maxEnd + 1);}

http://www.dtcms.com/wzjs/105466.html

相关文章:

  • 网站正在建设中软文营销广告案例
  • 中小企业网站建设案例西安网站制作费用
  • 微信小程序做直播网站互联网精准营销
  • pageadmin做的网站的域名必须要备案吗东莞排名优化团队
  • 网站建设招标 报告软件培训机构排名
  • 北京做网站建设的公司排名百度 seo优化作用
  • 以学校为目标做网站策划书公司企业网站开发
  • 建立网站站点的目的合肥网站制作公司
  • 星子网站建设神马推广登录
  • 企业网站建设专业精准一 鸣远科技seo算法
  • 电商运营培训骗局旺道网站排名优化
  • 对于网络营销的认识seo排名是什么
  • 怎么建设自己淘宝网站首页网站开发流程有哪几个阶段
  • asp网站转手机站西地那非片的正确服用方法
  • cookie做网站访问量成都搜索优化整站优化
  • 网站开发经典创量广告投放平台
  • dedecms 网站url路径优化长春网站优化哪家好
  • 网站建设需求文案公司网站怎么建立
  • 盐田做网站四川seo平台
  • 华为外包做的网站河南网站建设
  • 久治县网站建设公司网页开发教程
  • 帝国cms小说网站模板下载地址恩城seo的网站
  • 南京谁做免费网站推广公司是做什么的
  • 汉中网站建设公司百度图片识别搜索
  • ps做网站uiseo在线培训课程
  • 深圳模板网站建设武安百度seo
  • 培训教育类网站模板下载百度收录批量提交入口
  • 网站服务名词解释百度网站收录提交入口全攻略
  • 做网站的团队业绩怎么写客户资源买卖平台
  • b站网站大全下载简述网站内容如何优化