代码随想录算法训练营第四十九天|leetcode516、647题

embedded/2024/9/23 6:28:46/

1、leetcode第647题

本题要求找字符串中回文子串的数目,因此设置dp数组,dp[i][j]的含义是从下标i到j的子串是不是回文串,因此递推公式为:在s[i]=s[j]时如果间距小于等于1或者间距大于1时dp[i+1][j-1]为回文串则dp[i][j]也为回文串。dp数组为bool数组,dp数组初始化为false,最后统计为true的元素数即为最后的回文子串数。

具体代码如下:

class Solution {
public:int countSubstrings(string s) {vector<vector<bool>>dp(s.length(),vector<bool>(s.length(),false));int result =0;for(int i=s.length()-1;i>=0;i--){for(int j=i;j<s.length();j++){if(s[i]==s[j]){if(j-i<=1){dp[i][j]=true;result++;}else if(j-i>1&&dp[i+1][j-1]==true){dp[i][j]=true;result++;}}}}return result;}
};

二、leetcode第516题

本题要求最长回文子串的长度,设置dp数组,dp[i][j]的含义是下标为i到j的子串中最长回文子串的长度,递推公式为:s[i]=s[j]时,dp[i][j]=dp[i-1][j-1]+2,不等时,dp[i][j]=max(dp[i-1][j],dp[i][j-1])。

初始化时均设置为0,将dp[i][i]初始化为1。

具体代码如下:

class Solution {
public:int longestPalindromeSubseq(string s) {vector<vector<int>>dp(s.length(),vector<int>(s.length(),0));for(int i=0;i<s.length();i++){dp[i][i]=1;}for(int i=s.length()-1;i>=0;i--){for(int j=i+1;j<s.length();j++){if(s[i]==s[j]){dp[i][j]=dp[i+1][j-1]+2;}else{dp[i][j]=max(dp[i+1][j],dp[i][j-1]);}}}return dp[0][s.length()-1];}
};


http://www.ppmy.cn/embedded/6860.html

相关文章

SQL约束

文章目录 约束约束的分类&#xff1a;按照约束的作用效果不同唯一约束主键约束外键约束检查约束非空约束默认值约束 按照是否跟随列和字段属性来创建约束行级约束表级约束 创建约束创建唯一约束创建完表之后创建唯一约束创建表的同时创建唯一约束行级约束表级约束 创建主键约束…

CentOS配置LNS和VSR作为LAC建立L2TP隧道

正文共&#xff1a;1859字 13图&#xff0c;预估阅读时间&#xff1a;5 分钟 很久之前发过配置服务器上公网的文章&#xff08;我用100块钱把物理服务器放到了公网&#xff0c;省了几万块&#xff01;&#xff09;&#xff0c;当时服务端是CentOS 7的系统&#xff0c;L2TP拨号用…

关系型数据库的相关概念

表、记录、字段 表 一个实体集相当于一个表记录 一个实体相当于一个记录&#xff0c;在表中表表现为一行数据字段 一个字段相当于数据库表中的列 表的关联关系 一对一(一对一的表可以合并成一张表)一对多多对多 必须创建第三张表&#xff0c;该表通常称为联接表&#xff0c…

(vue)el-select选择框加全选/清空/反选

(vue)el-select选择框加全选/清空/反选 <el-form-item label"批次"><el-selectv-model"formInline.processBatch"multiplecollapse-tagsfilterableplaceholder"请选择"style"width: 250px"no-data-text"请先选择企业、日…

SQL表连接(Oracle)

表连接 表连接笛卡尔集 内连接 | INNER JOIN外连接左外连接右外连接全外连接 交叉连接特殊连接自然连接自连接不等值连接 子查询完全能用表连接代替&#xff0c;表连接才是重中之重&#xff01;&#xff01;&#xff01;&#xff01;&#xff01; 表连接 定义&#xff1a;将多…

C#到底属于编译型语言还是解释型语言?

C#是一种编译型语言&#xff0c;也称为静态类型语言&#xff0c;这意味着C#代码在运行之前需要经过编译器的编译处理&#xff0c;并生成一个可执行的本地代码文件&#xff08;通常是.exe或.dll文件&#xff09;。相反&#xff0c;解释型语言将代码转换为低级代码后直接执行&…

广东省道路货物运输资格证照片回执可手机线上办理

广东省道路运输资格证是从事道路运输业务、危险品道路运输人员的必要证件&#xff0c;而在办理该证件的过程中&#xff0c;驾驶员照片回执是一项必不可少的材料。随着科技的发展和移动互联网的普及&#xff0c;现在办理驾驶员照片回执已经不再需要亲自前往照相馆&#xff0c;而…

【Python】——列表

&#x1f383;个人专栏&#xff1a; &#x1f42c; 算法设计与分析&#xff1a;算法设计与分析_IT闫的博客-CSDN博客 &#x1f433;Java基础&#xff1a;Java基础_IT闫的博客-CSDN博客 &#x1f40b;c语言&#xff1a;c语言_IT闫的博客-CSDN博客 &#x1f41f;MySQL&#xff1a…