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

JAVA学习-练习试用Java实现“最长回文子串”

问题:

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

示例 1:

输入:s = "babad"
输出:"bab"
解释:"aba" 同样是符合题意的答案。
示例 2:

输入:s = "cbbd"
输出:"bb"
示例 3:

输入:s = "a"
输出:"a"
示例 4:输入:s = "ac"
输出:"a"

提示:

1 <= s.length <= 1000
s 仅由数字和英文字母(大写和/或小写)组成

解答思路:

以下是使用 Java 实现最长回文子串问题的代码:

public class LongestPalindrome {public static String longestPalindrome(String s) {int n = s.length();String longest = "";for (int i = 0; i < n; i++) {for (int j = i + 1; j <= n; j++) {String sub = s.substring(i, j);if (isPalindrome(sub) && sub.length() > longest.length()) {longest = sub;}}}return longest;}public static boolean isPalindrome(String s) {int left = 0, right = s.length() - 1;while (left < right) {if (s.charAt(left)!= s.charAt(right)) {return false;}left++;right--;}return true;}public static void main(String[] args) {String s = "babad";System.out.println(longestPalindrome(s));}}

在上述代码中,首先定义了一个'isPalindrome'方法用于判断一个字符串是否为回文串。然后,'longestPalindrome'方法通过遍历字符串的所有子串,并判断每个子串是否为回文串。如果是回文串且长度大于当前最长回文串的长度,则更新最长回文串。

最后,在'main'方法中,调用'longestPalindrome'方法对示例输入字符串's'进行处理,并输出结果。

这种方法的时间复杂度为 O(n^3),因为需要遍历所有可能的子串。对于较长的字符串,可能会导致性能问题。在实际应用中,可以考虑使用更优化的算法,如动态规划或中心扩展法,来提高效率。

(文章为作者在学习java过程中的一些个人体会总结和借鉴,如有不当、错误的地方,请各位大佬批评指正,定当努力改正,如有侵权请联系作者删帖。)

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

相关文章:

  • 深入探索Qt框架系列之信号槽原理(三)
  • npm镜像源管理、nvm安装多版本node异常处理
  • 异步编程的魔力:如何显著提升系统性能
  • 优选算法一:双指针算法与练习(移动0)
  • 数据结构第二篇【关于java线性表(顺序表)的基本操作】
  • 人工智能和大模型的区别
  • k8s处于pending状态的原因有哪些
  • 【C++】入门(一):命名空间、缺省参数、函数重载
  • 深入分析 Android Activity (四)
  • Java实现顺序表
  • 刷题笔记1:如何科学的限制数字溢出问题
  • 社区供稿丨GPT-4o 对实时互动与 RTC 的影响
  • 基于Linux的文件操作(socket操作)
  • C++面试题记录(网络)
  • YoloV8改进策略:卷积篇|基于PConv的二次创新|附结构图|性能和精度得到大幅度提高(独家原创)
  • 图论(从数据结构的三要素出发)
  • spark相关知识
  • K8S认证|CKA题库+答案| 12. 查看Pod日志
  • 【Java SE】 String、StringBuff和StringBuilder
  • 产品经理-需求分析(三)
  • Linux 编译器gcc/g++使用
  • adam优化器计算过程(tensorflow)
  • 【数据结构与算法 | 链表篇】力扣876
  • kubeadm引导欧拉系统高可用的K8S1.28.X
  • 【信息学奥赛】字典的键和值对换
  • 使用Django框架搭建Web应用
  • 我用Mybatis的方式封装了OLAP查询!
  • golang rune类型解析,与byte,string对比,以及应用
  • 重学java 51.Collections集合工具类、泛型
  • 多语言印度红绿灯系统源码带三级分销代理功能