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

中国直销公司排名前十西安seo顾问

中国直销公司排名前十,西安seo顾问,c2c网站建设,政协网站建设意义算法-动态规划/中心扩散法-最长回文子串 1 题目概述 1.1 题目出处 https://leetcode.cn/problems/longest-palindromic-substring 1.2 题目描述 2 动态规划 2.1 思路 dp[i][j] 表示[i,j]之间的字符串是否是回文。 那么,如果chars[i] chars[j]时,就…

算法-动态规划/中心扩散法-最长回文子串

1 题目概述

1.1 题目出处

https://leetcode.cn/problems/longest-palindromic-substring

1.2 题目描述

在这里插入图片描述

2 动态规划

2.1 思路

dp[i][j] 表示[i,j]之间的字符串是否是回文。
那么,如果chars[i] = chars[j]时,就有可能构成的子串为回文:

  1. 如果j - i < 3,则子串肯定是回文。比如 aba、aa、a
  2. 如果j - i >=3,则就会用到动态规划了,即 dp[i][j] = dp[i+1][j-1],也就是说 i的下一个字符和j的前一个字符组成的闭区间子串是否是回文,只要是那么本子序列也是。
  3. 这里有个重要的点,表达式为dp[i][j] = dp[i+1][j-1],也就是说i取决于i+1,j取决于j-1,所以遍历时需要i从大到小计算,而j需要从小到大计算。
  4. 遍历过程中,每当判断子序列为回文,就和之前已经找到的最大回文长度的比较,如果更长就更新,并记录下i、j
  5. 最后将字符串从i、j取子序列即可

2.2 代码

public class Solution {public String longestPalindrome(String s) {// 表示[i,j]之间的字符串是否是回文boolean[][] dp = new boolean[s.length()][s.length()];for(int i = 0; i < s.length(); i++) {// 定义同一个位置的为truedp[i][i] = true;}int maxLength = 0;int left = 0, right = 0;for (int i = s.length() - 1; i >= 0; i--) {for (int j = i + 1; j < s.length(); j++) {if (s.charAt(i) == s.charAt(j)) {if (j - i < 3) {dp[i][j] = true;} else {dp[i][j] = dp[i+1][j-1];}if (dp[i][j] && (j - i + 1 > maxLength)) {maxLength = j - i + 1;left = i;right = j;}}}}return s.substring(left, right+1);}}

2.3 时间复杂度

O(N^2)
在这里插入图片描述

2.4 空间复杂度

O(N^2)

3 中心扩散

3.1 思路

从左到右移动,每当移动一次后,往两边扩散,直到两侧边界字符不符合回文规则。

3.2 代码

public class Solution {int maxLength = 0;int left = 0, right = 0;public String longestPalindrome(String s) {for (int i = 0; i < s.length() - 1; i++) {// 字符串奇数长度时,中间一个字符串往两边扩散spread(i, i, s);// 字符串偶数长度时,中间两个字符串往两边扩散spread(i, i+1, s);}return s.substring(left, right+1);}private void spread(int i, int j, String s) {while (i >= 0 && j < s.length()) {if (s.charAt(i) != s.charAt(j)) {break;} i--;j++;}// 把多减了、加了的补上i++;j--;if (j - i + 1 > maxLength) {left = i;right = j;maxLength = j - i + 1;}}
}

3.3 时间复杂度

在这里插入图片描述
O(N^2)

3.4 空间复杂度

O(1)

参考文档

  • 动态规划、中心扩散
  • 图解马拉车算法
http://www.yidumall.com/news/87156.html

相关文章:

  • 重庆优化官网服务手机网站怎么优化
  • wordpress升级不了优化设计答案大全英语
  • 做网站开什么发票常见的网络推广方式
  • 爱网站推广优化建材企业网站推广方案
  • 婚礼策划网站模板怎样在百度答题赚钱
  • 误给传销公司做网站算犯罪吗网站查询平台
  • 长春网站建设公司dbd3对网络营销的认识800字
  • 知名网站建设公司好吗应用宝下载
  • 建设银行不会自动弹出网站深圳关键词seo
  • 电子商务网站建设设计报告seo搜索引擎优化工具
  • 用dw做的网站怎么发布到网上站长工具传媒
  • 个人备案网站可以做商城展示优化seo
  • 有了域名后怎样做网站鹤壁网站seo
  • 企业做网站公司排名口碑百度上传自己个人简介
  • 天津做家政的网站站长之家 站长工具
  • 网站最新点击量排名淘宝店铺推广方法
  • 网站评论管理怎么做网址推荐
  • 十四五学科专业建设规划上海seo顾问推推蛙
  • 学设计的网站有哪些内容怎样写营销策划方案
  • 营销型企业网站建设教案seo广告优化多少钱
  • 用vs怎么做网站的导航长沙互联网推广公司
  • 画册设计报价明细表外链seo推广
  • 建设网站用哪种语言网站提交收录入口链接
  • 做网站需要固定ip么加快实施创新驱动发展战略
  • 做电商网站有什语言好百度搜索榜
  • wordpress多重筛选主题西安百度推广优化托管
  • 长沙做网站企业营销策划及推广
  • 安庆市网站建设杭州seo外包服务
  • 有没有一起做网站的seo优化一般包括哪些内容
  • 怎么用优盘做网站登录密钥域名注册查询