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

力扣题解(最长回文子串)

5. 最长回文子串

给你一个字符串 s,找到 s 中最长的 回文子串

。思路:

对于第i个字符,可能的回文子串构成方式有两种,一种是以i位置元素为中心元素,向着两边扩展,一种是以i位置和i+1位置元素为中心,分别向两边扩展。因此对于每个字符i,按照上述两种方式分别求出以当前位置为中心的最长回文字串,然后判断最长是哪个即可。

class Solution {
public:string longestPalindrome(string s) {int n = s.size();if (n == 1)return s;int ret = 0;string ssret;for (int i = 0; i < n; i++){int j = 1;int len1 = 1;while (i - j >= 0 && i + j < n && s[i - j] == s[i + j]){len1 += 2;j++;}j = 0;int len2 = 0;while (i - j >= 0 && i + 1 + j < n && s[i - j] == s[i + j+1]){len2+=2;j++;}if (len1 > len2){if (ret < len1){ssret = s.substr(i - len1 / 2, len1);ret = len1;}}else{if (ret < len2){ssret = s.substr(i + 1 - len2 / 2, len2);ret = len2;}}}return ssret;}
};

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

相关文章:

  • 数据湖表格式 Hudi/Iceberg/DeltaLake/Paimon TPCDS 性能对比(Spark 引擎)
  • 脚本练习-每5分钟执行一次获取当前服务器的基本情况
  • 技术探索之kotlin浅谈
  • 机器学习之常用优化器
  • 机器学习基本概念,Numpy,matplotlib和张量Tensor知识进一步学习
  • 博客前端项目学习day01
  • java Collections.synchronizedCollection方法介绍
  • 力扣每日一题:3011. 判断一个数组是否可以变为有序
  • ubuntu 上vscode +cmake的debug调试配置方法
  • 使用Redis实现签到功能:Java示例解析
  • tableau标靶图,甘特图与瀑布图绘制 - 9
  • 双向链表专题
  • SpringCoud组件
  • 向量的定义和解释
  • IoTDB 集群高效管理:一键启停功能介绍
  • 一个spring boot项目的启动过程分析
  • 智驭未来:人工智能与目标检测的深度交融
  • 01MFC建立单个文件类型——画线
  • 免杀中用到的工具
  • [vite] Pre-transform error: Cannot find package pnpm路径过长导致运行报错
  • Promise总结
  • ROI 接口便捷修改
  • jenkins打包java项目报错Error: Unable to access jarfile tlm-admin.jar
  • SQL Server设置端口:跨平台指南
  • ActiveMQ-CVE-2023-46604
  • TensorBoard ,PIL 和 OpenCV 在深度学习中的应用
  • 【超音速 专利 CN117576413A】基于全连接网络分类模型的AI涂布抓边处理方法及系统
  • iPhone数据恢复篇:iPhone 数据恢复软件有哪些
  • Html5+Css3学习笔记
  • WPF学习(2) -- 样式基础