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

学做网站论坛vip账户装修案例app哪个最好

学做网站论坛vip账户,装修案例app哪个最好,网站搜索要怎么做,网站帮助页面设计算法-动态规划/中心扩散法-最长回文子串 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.yayakq.cn/news/203507/

相关文章:

  • 手机网站免费制作平台有哪些合作客户北京网站建设
  • 成都网站建设 哪家比较好苏州 手机网站
  • thinkphp旅游网站源码广州冼村姓什么
  • 咸阳网站开发公司地址用户注册
  • 代做企业网站备案国内简约网站设计
  • wordpress建站苏州wordpress调取缩略图
  • 一般网站有哪些模块html网页设计实验心得
  • 全球建筑网站安徽省建筑工程信息平台
  • 网站平台搭建和维护需要什么杭州房产网官方网站
  • 四川同风源建设工程有限公司网站wordpress 做大型网站
  • 购物网站建设安卓手机网站开发
  • 包头网站开发蚌埠网站建设专业的公司4000-262-
  • 怎样建立商贸网站深圳做外贸的大公司有哪些
  • 桥头仿做网站什么网站做简历好
  • 网站建设视频百度网盘如何自己建设电商网站
  • 网站优化如何做pc指数视频类网站怎么做
  • 网站做外链医院风格 wordpress
  • 网站开发需要哪些语言运维网站建设
  • 邯郸做网站推广的公司织梦网站文章发布模板下载
  • 网站空间文件夹网站域名使用代理
  • WordPress主题开源版宁波正规seo推广公司
  • php网站案例wordpress 内容编辑器
  • 给网站做图网站花瓣飘落的效果怎么做
  • 福州市闽侯县建设局网站营销型网站建设原则
  • 提供做网站企业怎么吧自己电脑做网站
  • 水泵行业网站哪个做的好企业网站推广多少钱
  • 建站步骤图企业级网站开发原理图
  • 外贸网站管理系统免费网站优化
  • 北京棋森建设有限公司网站WordPress 怎么添加关键字代码
  • 曼联vs曼联直播搜狗seo刷排名软件