leetcode - 5. Longest Palindromic Substring with Java

2024-02-28 21:48

本文主要是介绍leetcode - 5. Longest Palindromic Substring with Java,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

题目在我这里
方法一,大暴力

 public String longestPalindrome1(String s) {/*very force: O(s.length()^2)空间复杂度  O(1)*/int i=0;int j=0;boolean flag = false;int maxi = i;int maxj = j;for(i=0;i<s.length();i++){for(j=s.length()-1;j>i;j--){if(s.charAt(i)==s.charAt(j)){int ii = i;int jj = j;for(jj=j;jj>ii;jj--,ii++){if(s.charAt(ii)!=s.charAt(jj)){// flag = true;break;}}System.out.println(ii+"  -  "+jj);if(ii>=jj){flag = true;break;}}}if(flag){if(j-i > maxj-maxi){maxj = j;maxi = i;}}}if(s.length()==0){return "";}if(maxi>=maxj){return s.substring(0,1);}return s.substring(maxi,maxj+1);}

方法二,dp ( 69ms )

    public String longestPalindrome2(String s) {/*DP空间复杂度  O(N^2)时间复杂度  O(N^2)f(i,j)  = { true    (f(i+1,j-1)==true && s[i]==s[j]){ false    otherwisef(i,i)   = truef(i,i+1) = s[i] == s[i+1]*/int N = s.length();boolean dp[][] = new boolean[N][N];int max = 0;int a=0,b=0;if(N==0){return "";}for(int j=0;j<N;j++){for(int i=0;i<=j;i++){// System.out.println(i+" "+j+" "+s.charAt(i) +" "+ s.charAt(j));dp[i][j] = s.charAt(i) == s.charAt(j);if(i+1<N && j-1>=0 && j-i>=2){dp[i][j] = dp[i][j] && dp[i+1][j-1];}// System.out.println(j-i+1);if(dp[i][j] && j-i+1 > max){max = j-i+1;a = i;b = j;}}}for(boolean i[]: dp){System.out.println(Arrays.toString(i));}System.out.println(max+" "+a+" "+b);return s.substring(a,b+1);}

方法三,中心扩展法 (递归版) 6ms

    public String longestPalindrome3(String s) {/*中心扩展法空间复杂度  O(1)时间复杂度  O(N^2)*/if (s == null || s.length() < 1) return "";int a = 0;int b = 0;for(int i=0;i+1<s.length();i++){int len = Math.max(check(s,i,i), check(s,i,i+1));if(len > b-a+1){a = i - (len-1)/2;b = i + len/2;System.out.println(len+" "+a+ " "+b);}}return s.substring(a,b+1);}public int check(String s,int a,int b){while(a>=0 && b<s.length() && s.charAt(a)==s.charAt(b)){a--;b++;}// return new int[]{a,b};System.out.println(a+ " "+b);return b-a-1;}

方法四、Manacher ( 4ms )

    public String longestPalindrome4(String s) {/*ManacherO(n)a   b   c   b  0   1   2   3# a # b # c # b #0 1 2 3 4 5 6 7 8i < maxRight: m[i] = min(m[pos+(i-pos)], maxRight - i)*/if (s == null || s.length() < 1) {return "";}char ss[] = new char[s.length()*2+1];ss[0] = '#';for(int i=0;i<s.length();i++){ss[i*2+1] = s.charAt(i);ss[i*2+2] = '#';}   int man[] = new int[ss.length];int pos = 0;int maxRight = 0;int maxPos = 0;int maxLen = 0;for(int i=0;i<man.length;i++){if(i<maxRight){man[i] = Math.min(man[pos+pos-i],maxRight-i);}else{man[i] = 0;}while(i-man[i] >= 0 && i+man[i]<ss.length && ss[i+man[i]] == ss[i-man[i]]){man[i]++;}if(maxRight < i+man[i]){maxRight = i+man[i];pos = i;}if(man[i] > maxLen){maxLen = man[i];maxPos = i;}}System.out.println(maxLen+" "+maxPos);if(maxPos%2==1){return s.substring((maxPos-1)/2-(maxLen-1)/2,(maxPos-1)/2+(maxLen-1)/2+1);}else{return s.substring((maxPos-1)/2-(maxLen-1)/2+1,(maxPos-1)/2+(maxLen-1)/2+1);}}

这篇关于leetcode - 5. Longest Palindromic Substring with Java的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/756716

相关文章

Java Predicate接口定义详解

《JavaPredicate接口定义详解》Predicate是Java中的一个函数式接口,它代表一个判断逻辑,接收一个输入参数,返回一个布尔值,:本文主要介绍JavaPredicate接口的定义... 目录Java Predicate接口Java lamda表达式 Predicate<T>、BiFuncti

Spring Security基于数据库的ABAC属性权限模型实战开发教程

《SpringSecurity基于数据库的ABAC属性权限模型实战开发教程》:本文主要介绍SpringSecurity基于数据库的ABAC属性权限模型实战开发教程,本文给大家介绍的非常详细,对大... 目录1. 前言2. 权限决策依据RBACABAC综合对比3. 数据库表结构说明4. 实战开始5. MyBA

Spring Security方法级安全控制@PreAuthorize注解的灵活运用小结

《SpringSecurity方法级安全控制@PreAuthorize注解的灵活运用小结》本文将带着大家讲解@PreAuthorize注解的核心原理、SpEL表达式机制,并通过的示例代码演示如... 目录1. 前言2. @PreAuthorize 注解简介3. @PreAuthorize 核心原理解析拦截与

一文详解JavaScript中的fetch方法

《一文详解JavaScript中的fetch方法》fetch函数是一个用于在JavaScript中执行HTTP请求的现代API,它提供了一种更简洁、更强大的方式来处理网络请求,:本文主要介绍Jav... 目录前言什么是 fetch 方法基本语法简单的 GET 请求示例代码解释发送 POST 请求示例代码解释

Java图片压缩三种高效压缩方案详细解析

《Java图片压缩三种高效压缩方案详细解析》图片压缩通常涉及减少图片的尺寸缩放、调整图片的质量(针对JPEG、PNG等)、使用特定的算法来减少图片的数据量等,:本文主要介绍Java图片压缩三种高效... 目录一、基于OpenCV的智能尺寸压缩技术亮点:适用场景:二、JPEG质量参数压缩关键技术:压缩效果对比

Java调用C++动态库超详细步骤讲解(附源码)

《Java调用C++动态库超详细步骤讲解(附源码)》C语言因其高效和接近硬件的特性,时常会被用在性能要求较高或者需要直接操作硬件的场合,:本文主要介绍Java调用C++动态库的相关资料,文中通过代... 目录一、直接调用C++库第一步:动态库生成(vs2017+qt5.12.10)第二步:Java调用C++

springboot+dubbo实现时间轮算法

《springboot+dubbo实现时间轮算法》时间轮是一种高效利用线程资源进行批量化调度的算法,本文主要介绍了springboot+dubbo实现时间轮算法,文中通过示例代码介绍的非常详细,对大家... 目录前言一、参数说明二、具体实现1、HashedwheelTimer2、createWheel3、n

Java利用docx4j+Freemarker生成word文档

《Java利用docx4j+Freemarker生成word文档》这篇文章主要为大家详细介绍了Java如何利用docx4j+Freemarker生成word文档,文中的示例代码讲解详细,感兴趣的小伙伴... 目录技术方案maven依赖创建模板文件实现代码技术方案Java 1.8 + docx4j + Fr

SpringBoot首笔交易慢问题排查与优化方案

《SpringBoot首笔交易慢问题排查与优化方案》在我们的微服务项目中,遇到这样的问题:应用启动后,第一笔交易响应耗时高达4、5秒,而后续请求均能在毫秒级完成,这不仅触发监控告警,也极大影响了用户体... 目录问题背景排查步骤1. 日志分析2. 性能工具定位优化方案:提前预热各种资源1. Flowable

基于SpringBoot+Mybatis实现Mysql分表

《基于SpringBoot+Mybatis实现Mysql分表》这篇文章主要为大家详细介绍了基于SpringBoot+Mybatis实现Mysql分表的相关知识,文中的示例代码讲解详细,感兴趣的小伙伴可... 目录基本思路定义注解创建ThreadLocal创建拦截器业务处理基本思路1.根据创建时间字段按年进