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

网站地图制作网络热词2023流行语及解释

网站地图制作,网络热词2023流行语及解释,男友给女朋友做网站,电子商务网站开发论文目录 回文串问题 1.回文子串 2.最长回文子串 3.分割回文串4 本文旨在通过对力扣上三道题进行讲解来让大家对使用动态规划解决回文串有一定思路,培养大家对状态定义,以及状态方程书写的思维。 顺序: 题目链接-》算法思路-》代码呈现 回文串…

目录

 回文串问题

1.回文子串

2.最长回文子串

3.分割回文串4


        本文旨在通过对力扣上三道题进行讲解来让大家对使用动态规划解决回文串有一定思路,培养大家对状态定义,以及状态方程书写的思维。

顺序:

题目链接-》算法思路-》代码呈现

 回文串问题

动态规划类题目解题步骤:

  1. 依据题目进行状态表示(dp[i]的含义)
  2. 写出状态转移方程(类似于dp[i]=dp[i-1]+dp[i-2])
  3. 为防止填表时数组越界,对dp表进行初始化(dp[0]=dp[1]=1)
  4. 搞清楚填表顺序(从前往后或者从后往前)
  5. 利用dp表返回问题答案

1.回文子串

题目链接:

https://leetcode.cn/problems/palindromic-substrings/

算法思路:

我们可以先「预处理」⼀下,将所有⼦串「是否回⽂」的信息统计在 dp 表⾥⾯,然后直接在表⾥⾯统计 true 的个数即可。
1. 状态表⽰:
        为了能表⽰出来所有的⼦串,我们可以创建⼀个 n * n 的⼆维 dp 表,只⽤到「上三⻆部分」 即可。
其中, dp[i][j] 表⽰: s 字符串 [i, j] 的⼦串,是否是回⽂串。
2. 状态转移⽅程:
        对于回⽂串,我们⼀般分析⼀个「区间两头」的元素:
  1. s[i] != s[j] 的时候:不可能是回⽂串, dp[i][j] = 0
  2. s[i] == s[j] 的时候:根据⻓度分三种情况讨论:
  • ⻓度为 1 ,也就是 i == j :此时⼀定是回⽂串, dp[i][j] = true
  • ⻓度为 2 ,也就是 i + 1 == j :此时也⼀定是回⽂串, dp[i][j] = true
  • ⻓度⼤于 2 ,此时要去看看 [i + 1, j - 1] 区间的⼦串是否回⽂: dp[i][j] = dp[i + 1][j - 1] 。
综上,状态转移⽅程分情况谈论即可。
3. 初始化:
        因为我们的状态转移⽅程分析的很细致,因此⽆需初始化。
4. 填表顺序:
        根据「状态转移⽅程」,我们需要「从下往上」填写每⼀⾏,每⼀⾏的顺序⽆所谓。
5. 返回值:
        根据「状态表⽰和题⽬要求」,我们需要返回 dp 表中 true 的个数。

代码呈现:

class Solution {public int countSubstrings(String s) {char[] arr=s.toCharArray();int n=arr.length;boolean[][] dp=new boolean[n][n];for(int j=0;j<n;j++){for(int i=j;i>=0;i--){if(arr[i]==arr[j]){if(i==j){dp[i][j]=true;}else if(i+1==j){dp[i][j]=true;}else{dp[i][j]=dp[i+1][j-1];}}else{dp[i][j]=false;}}}int re=0;for(int i=0;i<n;i++){for(int j=0;j<n;j++){if(dp[i][j]==true){re++;}}}return re;}
}

2.最长回文子串

题目链接:

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

算法思路:

  1. 我们可以先⽤ dp 表统计出「所有⼦串是否回⽂」的信息
  2. 然后根据 dp 表⽰ true 的位置,得到回⽂串的「起始位置」和「⻓度」。
那么我们就可以在表中找出最⻓回⽂串。
关于「预处理所有⼦串是否回⽂」,已经在上⼀道题⽬⾥⾯讲过

代码呈现:

class Solution {public String longestPalindrome(String s) {char[] arr=s.toCharArray();int n=arr.length;int[][] dp=new int[n][n];for(int j=0;j<n;j++){for(int i=j;i>=0;i--){if(arr[i]==arr[j]){if(i==j){dp[i][j]=1;}else if(i+1==j){dp[i][j]=2;}else{if(dp[i+1][j-1]==0){dp[i][j]=0;}else{dp[i][j]=dp[i+1][j-1]+2;}}}else{dp[i][j]=0;}}}int max=0;String re="";for(int i=0;i<n;i++){for(int j=0;j<n;j++){if(max<dp[i][j]){max=dp[i][j];re=s.substring(i,j+1);}}}return re;}
}

3.分割回文串4

题目链接:

https://leetcode.cn/problems/palindrome-partitioning-iv/description/

算法思路:

题⽬要求⼀个字符串被分成「三个⾮空回⽂⼦串」,乍⼀看,要表⽰的状态很多,有些⽆从下⼿。
其实,我们可以把它拆成「两个⼩问题」:
  1. 动态规划求解字符串中的⼀段⾮空⼦串是否是回⽂串;
  2. 枚举三个⼦串除字符串端点外的起⽌点,查询这三段⾮空⼦串是否是回⽂串。
那么这道困难题就免秒变为简单题啦,变成了⼀道枚举题。
关于预处理所有⼦串是否回⽂,已经在上⼀道题⽬⾥⾯讲过。

代码呈现:

class Solution {public boolean checkPartitioning(String s) {char[] arr=s.toCharArray();int n=arr.length;boolean[][] dp=new boolean[n][n];for(int j=0;j<n;j++){for(int i=j;i>=0;i--){if(arr[i]==arr[j]){if(i==j){dp[i][j]=true;}else if(i+1==j){dp[i][j]=true;}else{dp[i][j]=dp[i+1][j-1];}}else{dp[i][j]=false;}}}for(int i=1;i<n-1;i++){for(int j=i;j<n-1;j++){if(dp[0][i-1]&&dp[i][j]&&dp[j+1][n-1]){return true;}}}return false;}
}

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

相关文章:

  • 提供专业网站建设平台今日头条热搜榜
  • 做网站界面设计大小谷歌关键词排名查询
  • 深圳网站建设php国内免费ip地址
  • 海南高端建设网站微博营销案例
  • 网站怎么做才能将名声打响莱阳seo外包
  • 网站上的按钮怎么做西安seo关键词排名优化
  • 网站的优化总结怎么写网店运营策划方案
  • 北京优化排名技术seo蜘蛛屯
  • 河南建设网站信息查询中心seo搜索优化公司报价
  • 您没有足够的权限访问该页面 wordpress企业网站seo公司
  • 网站便民服务平台怎么做有没有推广app的平台
  • 什么是自主设计网站seo在线优化工具 si
  • 自己做网站卖什么名字谷歌官网入口手机版
  • 网络营销策略相关理论百度推广优化师是什么
  • 淘宝客15套单页网站程序模板打包小学生摘抄新闻2024
  • 博爱网站建设女装标题优化关键词
  • 工控机做网站服务器网站管理和维护的主要工作有哪些
  • 日照网站建设哪家公司好百度查询关键词排名工具
  • 重庆网站制作招聘项目网站
  • 国外建筑网站app搜索引擎最新排名
  • 苍南哪里有网站建设公司网页设计用什么软件做
  • 淘宝做促销的网站网店营销与推广策划方案
  • 吉林省长春市长春网站建设哪家好百度指数怎么算
  • 黑色网站素材磁力最好用的搜索引擎
  • 泉州seo-泉州网站建设公司如何做好线上推广
  • 网站icp备案去哪办理网络营销应用方式
  • 东营网站建设网络营销竞价推广
  • 公司网站设计需要什么成功营销十大经典案例
  • 专业制作网站电脑2345网址导航删除办法
  • 做app网站建设自己的网站怎么在百度上面推广