leetcode-回文类题-647-求字符串中 回文子串 的数目

1、回文子串-647

题目:

给你一个字符串 s ,请你统计并返回这个字符串中 回文子串 的数目。

回文字符串 是正着读和倒过来读一样的字符串。

子字符串 是字符串中的由连续字符组成的一个序列。

示例 1:

复制代码
输入:s = "abc"
输出:3
解释:三个回文子串: "a", "b", "c"

示例 2:

复制代码
输入:s = "aaa"
输出:6
解释:6个回文子串: "a", "a", "a", "aa", "aa", "aaa"

思路:找出回文中心 向两边延申,判断是否是回文字符串,每移动一次res++;这是因为aca是回文子串,bacab也是回文子串,且要考虑边界值,使用方括号 [] 访问超出范围的索引会返回 undefined。要用charAt去处理l和r为负数的情况

题解:

javascript 复制代码
var countSubstrings = function(s){
  let res = 0;
  let n = s.length;
for(let i = 0;i<2*n-1;i++){            //对于字符串s有2n-1的回文中心
  let l = i/2;
  let r = i/2+i%2;
if(s.charAt(l)==s.charAt(r)&&l>=0&&r<n){
  res++;
  l++;
  r--;
}
}
return res;
}
相关推荐
hadage233几秒前
--- JavaScript 的一些常用语法总结 ---
java·前端·javascript
懂得节能嘛.15 分钟前
【Java动态线程池】Redis监控+动态调参
java·开发语言·redis
豆奶特浓622 分钟前
Java面试模拟:当搞笑程序员谢飞机遇到电商秒杀与AIGC客服场景
java·spring boot·微服务·面试·aigc·高并发·电商
明洞日记24 分钟前
【设计模式手册013】命令模式 - 请求封装的优雅之道
java·设计模式·命令模式
8***848226 分钟前
如何在Linux中找到MySQL的安装目录
linux·运维·mysql
方白羽31 分钟前
Android多层嵌套RecyclerView滚动
android·java·kotlin
9***J62836 分钟前
Linux下PostgreSQL-12.0安装部署详细步骤
linux·运维·postgresql
uup1 小时前
Java 中 ArrayList 线程安全问题
java
W***83201 小时前
如何在 Ubuntu 22.04 上安装 MySQL
linux·mysql·ubuntu
uup1 小时前
Java 中日期格式化的潜在问题
java