天池 在线编程 回文子串(区间动态规划)

文章目录

    • 1. 题目
    • 2. 解题

1. 题目

描述

小明喜欢玩文字游戏,今天他希望在一个字符串的子串中找到回文串。

回文串是从左往右和从右往左读相同的字符串,例如121tacocat。子串是一个字符串中任意几个连续的字符构成的字符串。

现在给你一个字符串s, 求出s的回文串个数?

例如,s=mokkori。它的一些子串是[m,o,k,r,i,mo,ok,mok,okk,kk,okko],每个粗体元素都是s的一个回文子串,总共有7个不同的回文。

1|s|5000
Each character s[i] ∈ ascii[a-z]
示例
样例1:
输入: 
str = "abaaa"
输出:  
5
说明:
5个回文子串
a
aa
aaa
aba
b样例2:
输入: 
str = "geek"
输出:  
4
说明:
4个回文子串
e
ee
g
k

https://tianchi.aliyun.com/oj/403980887914474330/460413730469122894
https://www.lintcode.com/problem/837/description

2. 解题

  • 区间动态规划,dp[i][j] 表示字符子串 [i:j] 是否是回文串,采用 set 记录去重
class Solution {
public:/*** @param s: the string* @return: the number of substring*/int countSubstrings(string &s) {// Write your code here.int n = s.size();vector<vector<int>> dp(n,vector<int>(n,0));set<char> set(s.begin(),s.end()); // 单个字符的子串unordered_set<string> oset;dp[0][0]=1;for(int i = 1; i < n; ++i){dp[i][i] = 1; // 单个字符肯定是回文串if(s[i-1] == s[i]){dp[i-1][i] = 1;oset.insert(s.substr(i-1,2));}}for(int len = 2; len <= n; ++len){for(int i = 0; i+len < n; ++i){if(dp[i+1][i+len-1] && s[i] == s[i+len]){dp[i][i+len] = 1;oset.insert(s.substr(i,len+1));}}}return set.size() + oset.size();}
};

LintCode 837 :不要求去重

class Solution {
public:/*** @param str: s string* @return: return an integer, denote the number of the palindromic substrings*/int countPalindromicSubstrings(string &s) {// write your code hereint n = s.size();vector<vector<int>> dp(n,vector<int>(n,0));int ans = n;dp[0][0]=1;for(int i = 1; i < n; ++i){dp[i][i] = 1;if(s[i-1] == s[i]){dp[i-1][i] = 1;ans++;}}for(int len = 2; len <= n; ++len){for(int i = 0; i+len < n; ++i){if(dp[i+1][i+len-1] && s[i] == s[i+len]){dp[i][i+len] = 1;ans++;}}}return ans;}
};

我的CSDN博客地址 https://michael.blog.csdn.net/

长按或扫码关注我的公众号(Michael阿明),一起加油、一起学习进步!
Michael阿明

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/472213.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

python读取html文件正则替换_Python正则获取和过滤或者替换HTML标签的方法说明

这篇文章主要介绍了Python通过正则表达式获取、过滤或者替换HTML标签的方法&#xff0c;感兴趣的小伙伴们可以参考一下本文实例介绍了Python通过正则表达式获取,去除(过滤)或者替换HTML标签的几种方法&#xff0c;具体内容如下python正则表达式转义符:. 匹配除换行符以外的任意…

【Python基础知识-pycharm版】第七节-函数

函数函数函数定义与调用形参和实参变量的作用域&#xff08;全局变量和局部变量&#xff09;局部变量和全局变量的测试参数的传递参数的几种类型位置参数默认值参数命名参数可变参数强制命名参数lambda表达式和匿名函数eval()函数用法递归函数_函数调用内存分析_栈帧的创建嵌套…

天池 在线编程 停车困境(双指针)

文章目录1. 题目2. 解题1. 题目 描述 停车场里停着许多汽车。 停车位是一条很长的直线&#xff0c;每米都有一个停车位。 当前很多汽车停放&#xff0c;您想通过建造屋顶来遮雨挡雨。 要求至少有k辆车的车顶被车顶遮盖&#xff0c;要覆盖k辆车的车顶的最小长度是多少&#xff…

《maven实战》笔记(2)----一个简单maven项目的搭建,测试和打包

参照《maven实战》在本地创建对应的基本项目helloworld&#xff0c;在本地完成后项目结构如下&#xff1a; 可以看到maven项目的骨架&#xff1a;src/main/java&#xff08;javaz主代码&#xff09;src/test/java&#xff08;测试代码&#xff09;src/main/resuources&#xff…

python自动复制_Python自动复制日志,python,拷贝

#!/usr/bin/env pythonimport osimport timeimport reimport osfrom time import sleepcmd3“adb pull /resources/map/BaiduMapAuto/bnav/log /Users/shixinfa/Desktop/0630/log”os.system(cmd3)while True:file1 os.stat(’/Users/shixinfa/Desktop/0630/InssdkLog’) # in…

python爬虫爬微信红包_python 微信红包

def redbags(money, num10):import randomchoice random.sample(range(1, money * 100), num - 1)choice.extend([0,money*100])choice.sort()return [(choice[i 1] - choice[i]) / 100 for i in range(num)]while True:money input(请输入你要发放的红包金额:).strip()num …

【Python基础知识-pycharm版】第八节-面向对象编程/类

面向对象编程面向对象和面向过程的区别_执行者思维_设计者思维类的定义构造函数__init__实例属性_内存分析实例方法_内存分析类对象类属性_内存分析创建类和对象的底层类方法_静态方法_内存分析图示__del__()析构方法和垃圾回收机制__call__()方法和可调用对象面向对象和面向过…

天池 在线编程 推荐朋友(哈希)

文章目录1. 题目2. 解题1. 题目 描述 给n个人的朋友名单&#xff0c;告诉你user是谁&#xff0c;请找出user最可能认识的人。&#xff08;他和user有最多的共同好友且他不是user的朋友&#xff09; n < 500。 好友关系是相互的。&#xff08;b若出现在a的好友名单中&#…

mr图像翻转的原因_MR的特殊检查脂肪抑制

让学习成为一种好习惯正文开始脂肪抑制脂肪抑制是指在MR成像中通过调整采集参数而选择性的抑制脂肪信号&#xff0c;使其失去高信号变为低信号&#xff0c;以区分同样为高信号的不同结构&#xff0c;在临床诊断上具有重要的意义&#xff0c;主要表现在&#xff1a;(1)减少运动伪…

Qt 图形特效(Graphics Effect)介绍

原文链接:Qt 图形特效(Graphics Effect)介绍 QGraphicsEffect也是Qt-4.6引入的一个新功能。它让给图形元素QGraphicsItem增加更佳视觉效果的编程变得非常简单。 先来看几张效果图。 上图中最上面的那个图片是没有使用QGraphicsEffect处理的原图&#xff0c;下面的四个图片分别代…

小米usb3.0修复补丁_今日热闻 | Redmi 10X系列发布、小米手环5产品外观曝光、Win10补丁导致蓝屏、AXON 11 SE 6月发布...

今日热点新闻realme X50 Pro 玩家版发布realme 通过线上发布会推出包括真我 X50 Pro 玩家版在内的 8 款新品。其中真我 X50 Pro 玩家版搭载高通骁龙 865 移动平台、6.44 寸 90Hz 刷新率 AMOLED 屏幕和 1216 超线性双扬声器&#xff0c;配备 VC 液冷散热、线性马达和 4200mAh 电…

【Python基础知识-pycharm版】第九节_面向对象的三大特征

第九节方法方法没有重载私有属性和私有方法&#xff08;实现封装&#xff09;property装饰器_get和set方法面向对象的三大特征说明(封装、继承、多态)继承方法的重写&#xff08;类成员的继承和重写&#xff09;查看类的继承结构object根类_dir() 查看对象属性重写__str__()方法…

LeetCode 1869. 哪种连续子字符串更长

文章目录1. 题目2. 解题1. 题目 给你一个二进制字符串 s 。如果字符串中由 1 组成的 最长 连续子字符串 严格长于 由 0 组成的 最长 连续子字符串&#xff0c;返回 true &#xff1b;否则&#xff0c;返回 false 。 例如&#xff0c;s "110100010" 中&#xff0c;…

如何通过像素点找到世界坐标_如何通过阅读来找到自己理论研究的“视域”?...

理论研究多用演绎法&#xff0c;也就是说&#xff0c;理论研究一般始于一个独特的概念、理论视角&#xff0c;或者判断。用刘良华的观点来说&#xff0c;这些都是理论研究的“视域”&#xff0c;也是理论研究得以展开的“大前提”。因此&#xff0c;理论研究最为关键的问题&…

任务并行VS数据并行

并行计算中&#xff0c;有两种并行的方法&#xff1a;任务并行&#xff08;task-parallelism&#xff09;和数据并行&#xff08;data-parallelism&#xff09;。任务并行&#xff1a;将许多可以解决问题的任务分割&#xff0c;然后分布在一个或者多个核上进行程序的执行。数据…

免费python基础笔记_python基础笔记(一)

1、就单个 python 文件来说在 python 中 python 的后缀可以是任意的。但如果这个 python 文件需要导入的时候如果不是 .py 会出错。所以一般情况下 python 文件的后缀为 .py2、是 linux 中使用 ./文件.py 时候需要在文档的第一行注明解释器路径# !/usr/bin/env/ python3、声明…

【Python基础知识-pycharm版】第十节_异常

第十节异常异常机制本质异常解决的关键&#xff1a;定位try... 一个 except 结构try... 多个 except 结构try...except...else 结 构try...except...finally 结构return 语句和异常处理问题常见异常的解决常见异常汇总with 上下文管理trackback 模块自定义异常类异常 在实际工…

k8s挂载目录_拥抱云原生,如何将开源项目用k8s部署?

k8s以及云原生相关概念近年来一直比较火热&#xff0c;阿丸最近搞了个相关项目&#xff0c;小结一下。本文将重点分享阿里开源项目otter适配k8s部署的改造过程&#xff0c;其中的改造过程和技巧应该适用于将大多数开源项目改造到k8s进行部署。1.背景otter是阿里开源的分布式数据…

LeetCode 1870. 准时到达的列车最小时速(二分查找)

文章目录1. 题目2. 解题2.1 模拟超时2.2 二分查找1. 题目 给你一个浮点数 hour &#xff0c;表示你到达办公室可用的总通勤时间。 要到达办公室&#xff0c;你必须按给定次序乘坐 n 趟列车。 另给你一个长度为 n 的整数数组 dist &#xff0c;其中 dist[i] 表示第 i 趟列车的行…

jdk1.5新特性

“JDK1.5”&#xff08;开发代号猛虎&#xff09;的一个重要主题就是通过新增一些特性来简化开发&#xff0c;这些特性包括泛型&#xff0c;for-else 循环&#xff0c;自动装包/拆包&#xff0c;枚举&#xff0c;可变参数, 静态导入 。使用这些特性有助于我们编写更加清晰&…