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

做自媒体都有什么网站网销具体怎么做网站

做自媒体都有什么网站,网销具体怎么做网站,建设工程施工合同2021,朝阳区手机网站设计服务文章目录 动态规划#xff08;回文串问题#xff09;1. 回文子串2. 最长回文子串3. 回文串分割 IV4. 分割回文串 ||5. 最长回文子序列6. 让字符串成为回文串的最小插入次数 动态规划#xff08;回文串问题#xff09; 1. 回文子串 题目链接 状态表示 f[i][j]表示 i 到 j … 文章目录 动态规划回文串问题1. 回文子串2. 最长回文子串3. 回文串分割 IV4. 分割回文串 ||5. 最长回文子序列6. 让字符串成为回文串的最小插入次数 动态规划回文串问题 1. 回文子串 题目链接 状态表示 f[i][j]表示 i 到 j 的子串当中是否是回文 状态转移方程 初始化 最初所有的内容都是0即可 填表 因为 i j 需要用 i 1 来初始化所以这个时候需要从下往上填表 返回值 返回整个dp 表里true 的数目就可以 AC代码: class Solution { public:int countSubstrings(string s) {int n s.size();vectorvectorbool dp(n, vectorbool(n));int ret 0;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]) ret;}}return ret;} };2. 最长回文子串 题目链接 如果需要求一个字符串当中的最长的回文子串需要将所有的回文子串找到然后再所有的回文子串里面找打一个最长的就可以了 可以参考上一个题目回文子串 AC代码 class Solution { public:string longestPalindrome(string s) {// 找到所有的回文子串int n s.size();vectorvectorbool dp(n, vectorbool(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);} };3. 回文串分割 IV 题目链接 分析如果暴力解题的话i 和 j 可以把整个字符串分为3份只需要遍历所有可能分为3份的情况直接判断是否都是回文串不就可以了。但是判断回文串需要花费时间可以使用上面两道题的方法来判断是不是回文串 AC代码 class Solution { public:bool checkPartitioning(string s) {int n s.size();vectorvectorbool dp(n, vectorbool(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;} };4. 分割回文串 || 题目链接 状态表示 dp[i]表示0 到 i 之间可以把所有子串都分割为回文串的最小次数 状态转移方程 初始化 所需初始位最大即可 填表 从左到右 返回值 AC代码 class Solution { public:int minCut(string s) {int n s.size();vectorvectorbool isPal(n, vectorbool(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;}}vectorint 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[i], dp[j - 1] 1);}}}return dp[n - 1];} };5. 最长回文子序列 题目链接 状态表示 之前以某个位置为结尾来分析状态表示如果dp[i]表示到i位置的最长回文子序列的长度来推导状态转移方程只有长度是分析不出来状态转移方程。 dp[i][j]表示i j 这个区间内最长的回文子序列的长度 状态转移方程 初始化 无需初始化 填表 因为需要用到 后面的值所以填表需要从下到上从左到右 返回值 AC代码 class Solution { public:int longestPalindromeSubseq(string s) {int n s.size();vectorvectorint dp(n, vectorint(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 j ? 1 : dp[i 1][j - 1] 2;}else dp[i][j] max(dp[i 1][j], dp[i][j - 1]);}}return dp[0][n - 1];} };6. 让字符串成为回文串的最小插入次数 题目链接 状态表示 dp[i][j]表示i 到 j 这个区间内成为回文串的最小插入次数 状态转移方程 初始化 填表 从下往上从左到右 返回值 AC代码 class Solution { public:int minInsertions(string s) {int n s.size();vectorvectorint dp(n, vectorint(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] : 0;else dp[i][j] min(dp[i 1][j], dp[i][j - 1]) 1;}}return dp[0][n - 1];} };
http://www.w-s-a.com/news/689285/

相关文章:

  • 专业做房地产网站建设wordpress侧面小工具
  • 旅游网站开发的重要性wordpress添加广告插件
  • 关于网站建设管理工作的报告婚纱网站php
  • 东莞市建设培训中心网站那个网站可以看高速的建设情况
  • 网站开发工具安卓版专业小程序商城开发
  • 网站不备案影响收录吗深圳住房网站app
  • 交网站建设域名计入什么科目开发平台教程
  • 个人网站定制北京快速建站模板
  • 河南海华工程建设监理公司网站高端论坛网站建设
  • 网站建设网络推广方案图片编辑器免费
  • 如何用dw做网站设计设计头条
  • 网站建设基础及流程北京商场购物中心排名
  • 青州市城乡建设局网站自建网站步骤
  • wordpress文章延迟加载优化设计答案四年级上册语文
  • 做网站源码要给客户嘛怎么在运行打开wordpress
  • 北海住房和城乡建设局网站wordpress标题去掉私密
  • 织梦网站安装视频做网站都有那些步骤
  • 网站空间大小选择沈阳微信网站制作
  • 网站分享对联广告网站结构的类型
  • 三维家是在网站上做还是在app上北京网站建设 专业10年
  • 模拟网站建设网站建设认准猪八戒网
  • godaddy网站建设教程微信手机网站搭建
  • 网站建设 商城淄博网站制作哪家好
  • 廊坊手机网站团队国际贸易进口代理公司
  • 运用django做网站网站建设问题及解决办法
  • 商丘企业网站服务c mvc 网站开发
  • 太仓建设工程网站广州seo排名外包
  • 成都的教育品牌网站建设做网站不给提供ftp
  • 建站行业市场人力管理系统
  • qq钓鱼网站在线生成器google关键词搜索工具