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

赌博游戏网站开发郑州seo阿伟

赌博游戏网站开发,郑州seo阿伟,网站建设制作方案,直销购物网站开发目录 引例 其余经典OJ题 1.第一题 2.第二题 3.第三题 4.第四题 5.第五题 引例 OJ 传送门Leetcode<647>回文子串 画图分析&#xff1a; 使用动态规划解决 原理&#xff1a;能够将所有子串是否是回文的信息保存在dp表中 在使用暴力方法枚举出所有子串&#xff0c;是…

目录

引例

其余经典OJ题

1.第一题

 2.第二题

 3.第三题

4.第四题 

 5.第五题

引例

OJ 传送门Leetcode<647>回文子串

画图分析:

使用动态规划解决

原理:能够将所有子串是否是回文的信息保存在dp表中

在使用暴力方法枚举出所有子串,是使用两指针(i,j)依次往后枚举的,且满足i<=j

所以需要建立二维的dp表,在填表时只需填上三角位置即可

1.状态表示:

dp[i][j]表示字符串s的[i,j](i是起始位置,j是结束位置)的这个子串是否是回文

2.状态转移方程

对于线性dp可以采用多画图的方式来分析

3.初始化

因为满足i<=j 并且越界的情况都已经被判断了,是无需做初始化的

4.填表顺序

因为在求dp[i][j]时会用到dp[i+1][j-1]的值,所以填表顺序是整体从下往上,每一行从左往右

5.返回值

返回dp表中true的数量

具体代码

int countSubstrings(string s) {int n=s.size();vector<vector<bool>> dp(n,vector<bool>(n));//创建dp表int ret=0;for(int i=n-1;i>=0;--i)//填表{for(int j=i;j<n;++j)//从i位置开始往后枚举{if(s[i]==s[j]){dp[i][j]=i+1<j? dp[i+1][j-1]:true;}if(dp[i][j]) ++ret;}}return ret;//返回}

其余经典OJ题

1.第一题

OJ 传送门Leetcode<5>最长回文子串

画图分析:

使用动态规划解决

对于本道题是计算最长的回文子串,在上面的例题中已经实现了判断字符串的子串是否是回文,只需在dp表中为true的位置找出最长的回文串

其余的参考上面的例题

5.返回值

在dp表中为true的位置找出最长回文串的起始位置i及长度,返回子串

具体代码:

string longestPalindrome(string s) {int n=s.size();vector<vector<bool>> dp(n,vector<bool>(n));int begin=0,len=1;for(int i=n-1;i>=0;--i){for(int j=i;j<n;++j){if(s[i]==s[j]){dp[i][j]=i+1<j? dp[i+1][j-1]:true;}if(dp[i][j] && j-i+1>len){begin=i;len=j-i+1;}}}return s.substr(begin,len);}

 2.第二题

OJ 传送门Leetcode<1745>分割回文串IV

画图分析:

 使用动态规划来解决

对于本题是将字符串划分为三子串,只要每个子串是回文串即可

这里可以两下标i,j来划分这个字符串

此时只需要根据上面例题所实现的dp表来逐步划分区间判断 

具体代码:

 bool checkPartitioning(string s) {int n=s.size();//用dp把所有的子串是否是回文预处理一下vector<vector<bool>> dp(n,vector<bool>(n));for(int i=n-1;i>=0;--i){for(int j=i;j<n;++j){if(s[i]==s[j]){dp[i][j]=i+1<j? dp[i+1][j-1]:true;}}}//枚举所有的第二个子串的起始位置及结束位置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;}

 3.第三题

OJ 传送门Leetcode<132>分割回文串II

画图分析:

 使用动态规划来解决

1.状态表示  ---经验+题目要求

dp[i]表示字符串s.substr(0,i+1)这个子串要分割为回文串的最少分割次数

2.状态转移方程

3.初始化

对于这里的dp表本身在填表时由于j>0是不会访问越界的,但题目求得是最小值

在求dp[i]=min(dp[j-1]+1,dp[i])时,若初始化时都0时,dp[i]=0,是会影响求min的,因此初始化为INT_MAX

4.填表顺序 ------从左往右

5.返回值-------dp[n-1]

具体代码:

int minCut(string s) {//预处理一下int n=s.size();vector<vector<bool>> IsPal(n,vector<bool>(n));for(int i=n-1;i>=0;--i)for(int j=i;j<n;++j)if(s[i]==s[j])IsPal[i][j]=i+1<j? IsPal[i+1][j-1]:true;vector<int> dp(n,INT_MAX);  for(int i=0;i<n;++i){if(IsPal[0][i]) dp[i]=0;else{for(int j=1;j<=i;++j)if(IsPal[j][i]) dp[i]=min(dp[j-1]+1,dp[i]);}}return dp[n-1];}

4.第四题 

OJ 传送门Leetcode<516>最长回文子序列

画图分析:

 使用动态规划解决

1.状态表示

dp[i]表示以i位置为结尾的所有子序列中,最长回文子序列的长度

当使用此状态表示来求解状态转移方程时 

当求解dp[i]时,因为此题是子序列,所以需要用到dp[i-1],dp[i-2],....,而dp表中存的只是长度,当在每种结果后添加字符s[i]后,并不能保证是继续是回文串,因此推导不出状态转移方程

这时可以借用上面例题的方法来解决这题

状态表示:

dp[i][j]表示s字符串[i,j]区间内的所有子序列,最长回文子序列的长度 

2.状态转移方程

3.初始化

对于本题可以不用初始化,会越界的位置为i==j,而这些位置已经判断过了

 4.填表顺序

整体从上往下,每一行从左往右

5.返回值 dp[0][n-1]

具体代码:

int longestPalindromeSubseq(string s) {int n=s.size();vector<vector<int>> dp(n,vector<int>(n));for(int i=n-1;i>=0;--i){for(int j=i;j<n;++j){if(s[i]==s[j]){if(i==j) dp[i][j]=1;else dp[i][j]=dp[i+1][j-1]+2;}elsedp[i][j]=max(dp[i+1][j],dp[i][j-1]);}}return dp[0][n-1];}

 5.第五题

OJ 传送门Leetcode<1312>让字符串成为回文串的最少插入次数

画图分析:

 使用动态规划解决

1.状态表示 根据经验+题目要求

dp[i][j]表示:s字符串[i,j]区间的子串,让它变为回文串的最小操作次数

2.状态转移方程---认识根据s[i]与s[j]的关系来判断

3.初始化:

4.填表顺序

整体从下往上,每一行从左往右

5.返回值   dp[0][n-1]

具体代码:

 int minInsertions(string s) {int n=s.size();vector<vector<int>> dp(n,vector<int>(n));for(int i=n-1;i>=0;--i){for(int j=i+1;j<n;++j){if(s[i]==s[j]) dp[i][j]=dp[i+1][j-1];else dp[i][j]=min(dp[i][j-1],dp[i+1][j])+1;}}return dp[0][n-1];}
http://www.hkea.cn/news/289262/

相关文章:

  • 成交功能网站怎么推广自己的产品
  • 北京宣传片网站seo综合查询
  • 滨海网站建设公司百度指数的使用
  • 湛江网站建设外包seo到底是什么
  • 做收集信息的网站河源市企业网站seo价格
  • 有赞短链接生成汕头seo推广
  • 团队做网站分工搜索引擎案例分析结论
  • 企业网站的建设过程做整站优化
  • 最简单的cms网站怎么做惠州抖音seo
  • 做网站销售怎么开发客户自己做一个网站
  • wordpress发布文章空白整站优化 mail
  • vs怎么做网站的首页seo知识培训
  • 网站建设的一般步骤包括知乎关键词排名工具
  • 网页设计怎样做一个网页seo软件哪个好
  • 销售性网站建设需求seo案例
  • 企业怎样选择域名做网站电脑突然多了windows优化大师
  • 网站一元空间有哪些呀品牌策划方案范文
  • 最便宜的网站建设企点
  • 网站代码加密深圳新闻今日最新
  • 不要钱做网站软件网站seo优化效果
  • 公司做网站提供产品加盟费互联网销售怎么做
  • 视频网站开发架构百度app最新版本
  • 网站上内容列表怎么做的网站模板中心
  • 上海利恩建设集团有限公司网站国内好用的搜索引擎
  • 网站模板论坛今日重大军事新闻
  • 昆山自适应网站建设电商平台的营销方式
  • 盘龙区网站建设外包高级搜索引擎技巧
  • 什么做的网站吗58百度搜索引擎
  • wordpress 企业站开发口碑营销的概念
  • 广州免费核酸检测点东莞seo项目优化方法