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

代码随想录Day59 | 647. 回文子串 | 516. 最长回文子序列

647. 回文子串

        

class Solution {
public:int countSubstrings(string s) {int sum=0;int n=s.size();vector<vector<int>> f(n+1,vector<int>(n+1,0));//表示区间范围[i,j] (注意是左闭右闭)的子串是否是回文子串。初始值为0.for(int i = n-1;i>=0;i--){for(int j=i;j<n;j++){
/*如果这矩阵是从上到下,从左到右遍历,那么会用到没有计算过的f[i + 1][j - 1],也就是根据不确定是不是回文的区间[i+1,j-1],来判断了[i,j]是不是回文,那结果一定是不对的。
所以一定要从下到上,从左到右遍历,这样保证f[i + 1][j - 1]都是经过计算的。*/if(s[i]==s[j]){  //如果判断的子串首尾字符相等if(j-i<=1){  //子串长度为1或2,则一定是回文串sum++;f[i][j]=1;}else if(f[i+1][j-1]==1) //首部右移一个字符,尾部左移一个字符,仍是回文串,则就是回文串。{sum++;f[i][j]=1;}}}}return sum;}
};

516. 最长回文子序列

class Solution {
public:int longestPalindromeSubseq(string s) {int n=s.size();vector<vector<int>> f(n,vector<int>(n,0)); //f[i][j]:从第i到j个字符回文串的最长长度for(int i=0;i<n;i++) f[i][i]=1;for(int i=n-1;i>=0;i--){for(int j=i+1;j<n;j++){if(s[i]==s[j]){f[i][j]=f[i+1][j-1]+2;}else{f[i][j]=max(f[i+1][j],f[i][j-1]);}}}return f[0][n-1];}
};

http://www.lryc.cn/news/183705.html

相关文章:

  • 为什么InnoDB选择B+树而不是红黑树作为索引结构?
  • 【c++_containers】10分钟带你学会list
  • LeetCode 0714. 买卖股票的最佳时机含手续费
  • cartographer-(0)-ubuntu(20.04)-环境安装
  • MIT 6.S081学习笔记(第二章)
  • L958. 二叉树的完全性检验 java
  • 阿里云对象存储OSS SDK的使用
  • 二、互联网技术——网络协议
  • 初赛错题集
  • Java Thread类详解
  • 3_使用传统CNN网络训练图像分类模型
  • Java 创建线程的方法
  • 基于安卓android微信小程序的旅游app系统
  • C++设计模式-单件(Singleton)
  • 想做好接口测试,先把这些概念搞清楚了
  • 通过融合UGV的地图信息和IMU的惯性测量数据,实现对车辆精确位置和运动状态的估计和跟踪研究(Matlab代码实现)
  • 『Linux』Linux环境搭建 | 阿里云云服务器白嫖 | Xshell环境配置
  • C++ 类和对象篇(五) 析构函数
  • find 与 cp 命令组合使用
  • 用VLD调查VC内存泄漏
  • 【Java 进阶篇】使用 JDBCTemplate 执行 DQL 语句详解
  • 了解了spring mvc web容器中一个http请求的全过程,能给我们提升多少武力值
  • 【BBC新闻文章分类】使用 TF 2.0和 LSTM 的文本分类
  • set和map的封装
  • java基础练习--基础语法
  • Android12 OTA编译差分包报错问题
  • 现代c++手撸2309神经网络最简化版230901
  • Qt之显示PDF文件
  • [极客大挑战 2019]FinalSQL - 异或盲注
  • 【Go语言实战】(25) 分布式算法 MapReduce