[Java]LeetCode5 Longest Palindromic Substring
2015-06-19 10:47
543 查看
Given a string S, find the longest palindromic substring in S. You may assume that the maximum length of S is
1000, and there exists one unique longest palindromic substring.
题意:求字符串中最长的回文
感觉这题不难,可以这样想,设置两个指针,分别对应0,len-1。
比如从第一个字符开始,abababac,我们可以找a出现的位置,然后以第一个a与每个a作为一段。判断每一段是否是回文,因为是从后往前查找的,所以第一个找到的肯定是这一次查找中最长的回文,然后一次第2个字符,第3个字符。这个想法在字符串中的字符不一样的时候比较好。但是如果字符中出现的例如aaaaaabcaaaaa这样的话,就不佳了。在leetcode中一测试,果然Time
Limited。
第二个想法,算是逆推法,既然求的是回文,回文的字符是对称的。我们可以先确定回文的中心,回文的中心,奇数的时候是一个,偶数的时候是两个。分别向中心的两边进行匹配,判断是否相等,从而计算回文的长度。
代码如下:
1000, and there exists one unique longest palindromic substring.
题意:求字符串中最长的回文
感觉这题不难,可以这样想,设置两个指针,分别对应0,len-1。
比如从第一个字符开始,abababac,我们可以找a出现的位置,然后以第一个a与每个a作为一段。判断每一段是否是回文,因为是从后往前查找的,所以第一个找到的肯定是这一次查找中最长的回文,然后一次第2个字符,第3个字符。这个想法在字符串中的字符不一样的时候比较好。但是如果字符中出现的例如aaaaaabcaaaaa这样的话,就不佳了。在leetcode中一测试,果然Time
Limited。
第二个想法,算是逆推法,既然求的是回文,回文的字符是对称的。我们可以先确定回文的中心,回文的中心,奇数的时候是一个,偶数的时候是两个。分别向中心的两边进行匹配,判断是否相等,从而计算回文的长度。
代码如下:
public static String longestPalindrome(String s) { if(s.isEmpty()||s.length()==1)return s; String longest=s.substring(0,1); for(int i=0;i<s.length();i++) { //将i作为中心,获取最长的字符串 String tmp=isPalindrome(s,i,i); if(tmp.length()>longest.length())longest=tmp; //将i,i+1作为中心,获得最长的字符串 tmp=isPalindrome(s,i,i+1); if(tmp.length()>longest.length())longest=tmp; } return longest; } private static String isPalindrome(String s, int start, int end) { // TODO Auto-generated method stub while(start>=0&&end<=s.length()-1&&s.charAt(start)==s.charAt(end)) { start--; end++; } return s.substring(start+1,end); }
相关文章推荐
- java IO 笔记
- Eclipse 优化方法(经典收藏)
- java基础—自定义一个比较器,按照字符串的长度升序的方法来比较字符串进行储存(java集合三)
- Java中对单个或多个字段进行排序
- eclipse将引用了第三方jar包的java项目打成jar包
- java基础—自定义一个比较器,对TreeSet 集合中的元素按指定方法来排序(java集合六)
- uartz Spring与Spring Task总结
- JAVA一种提升输出速度的方法
- 23、java 通过System.getProperties()获取系统参数
- Eclipse远程weblogic调试
- eclipse下看android support v4源码
- eclipse下看android support v4源码
- Google Java 编码规范
- Spring任务调度器之Task的使用
- java基础—TreeSet集合中储存自定义对象(java集合二)
- [Java开发] jetty访问jsp页面出现( PWC6345: There is an error in invoking javac)
- spring mvc工作原理
- Spring中配置和读取多个Properties文件
- 史上最详细版!java文件打包成exe,在未配置安装JDK和未配置的电脑上运行
- Eclipse快捷方式