Given a string S, find the longest palindromic substring in S. You may assume that the maximum length of S is , and there exists one unique longest palindromic substring.

自己的解决方案;

public class Solution {
StringBuilder longest = new StringBuilder(""); public String longestPalindrome(String s) {
String ss;
int len = s.length();
int max = 0;
int sublen = 0;
String result = "";
for (int i = 0; i < len; i++) {
for (int j = i + 1; j < len; j++) {
ss = s.substring(i, j);
int index = s.indexOf(reverse(ss),j-1);
if (index == j - 1) {
sublen = 2 * (j - 1 - i) + 1;
if (sublen > max) {
max = sublen;
result = s.substring(i, max+i);
}
continue;
} else if (index == j) {
sublen = 2 * (j - i);
if (sublen > max) {
max = sublen;
result = s.substring(i, max+i);
}
continue;
} else {
continue;
}
}
} return result;
} public String reverse(String s) {
StringBuilder sb = new StringBuilder(s);
sb.reverse();
return sb.toString();
}
}

方法正确性是没有问题的,先挨个取子串,查找反串。但在LeetCode上会报超时错误。

参考讨论区的解答

Runtime: 344 ms

在所有JAVA程序里相对靠前

public class Solution {
StringBuilder longest = new StringBuilder(""); public String longestPalindrome(String s) {
if (s.length() <= 1) return s; for (int i = 0; i < s.length(); i++) {
expand(s, longest, i, i); //odd
expand(s, longest, i, i + 1); //even
} return longest.toString();
} private void expand(String s, StringBuilder longest, int i, int j) {
while (i >= 0 && j < s.length()) {
if (s.charAt(i) == s.charAt(j)) {
if (j - i + 1 > longest.length()) {
longest.delete(0, longest.length());
longest.append(s.substring(i, j + 1));
}
i--;
j++;
}
else
break;
}
}
}

代码剖析:

以字符串basdsa为例:

b a s d s a

i=:

odd对应的while循环执行
i=,j=
if (s.charAt(i) == s.charAt(j)) 满足 longest=b
even对应的while循环不满足 if (s.charAt(i) == s.charAt(j))条件break i=: odd对应的while循环执行
i=,j=
if (j - i + > longest.length()) 不满足
i=,j= if (s.charAt(i) == s.charAt(j)) 不满足循环退出
even对应的while循环不满足 if (s.charAt(i) == s.charAt(j))条件break i=: odd对应的while循环执行
i=, j=
if (j - i + > longest.length()) 不满足
i=,j= if (s.charAt(i) == s.charAt(j)) 不满足循环退出
even对应的while循环不满足 if (s.charAt(i) == s.charAt(j))条件break i=: odd对应的while循环执行
i=, j=
if (j - i + > longest.length()) 不满足
i=,j= if (s.charAt(i) == s.charAt(j)) 满足 longest=sds
i=,j= if (s.charAt(i) == s.charAt(j)) 满足 longest=asdsa
i=,j=6不满足while条件退出
even对应的while循环不满足 if (s.charAt(i) == s.charAt(j))条件break i=: odd对应的while循环执行
i=, j=
if (j - i + > longest.length()) 不满足
i=,j= if (s.charAt(i) == s.charAt(j)) 不满足循环退出
even对应的while循环不满足 if (s.charAt(i) == s.charAt(j))条件break i=: odd对应的while循环执行
i=, j=
if (j - i + > longest.length()) 不满足
i=, j=6不满足while条件退出
even对应的while不满足while条件退出

Longest Palindromic Substring2015年6月20日的更多相关文章

  1. 中国式商业智能报表ActiveReports免费公开课,10月20日开讲

    ActiveReports公开课全方位报表解决方案,满足商业报表五大需求 [开课时间]10月20日[主讲老师]葡萄城报表产品经理[开课形式]网络在线公开课[活动费用]前50名免费 适合人群:报表开发人 ...

  2. 2016年12月20日 星期二 --出埃及记 Exodus 21:15

    2016年12月20日 星期二 --出埃及记 Exodus 21:15 "Anyone who attacks his father or his mother must be put to ...

  3. 2016年11月20日 星期日 --出埃及记 Exodus 20:11

    2016年11月20日 星期日 --出埃及记 Exodus 20:11 For in six days the LORD made the heavens and the earth, the sea ...

  4. 2016年10月20日 星期四 --出埃及记 Exodus 19:4

    2016年10月20日 星期四 --出埃及记 Exodus 19:4 `You yourselves have seen what I did to Egypt, and how I carried ...

  5. 【公告】CSDN个人空间将于2014年4月20日全新改版上线

    尊敬的用户:   你们好!           CSDN个人空间将在2014年4月20日全新改版上线!        CSDN个人空间是2008年8月推出的服务,致力于给广大用户提供在线技术分享和资料 ...

  6. 西安活动 | 4月20日「拥抱开源,又见.NET :云时代 • 新契机」

    云计算日渐兴起,成为提升企业效率和生产力的最终解决方案,而云时代也为软件开发模式带来了翻天覆地的变化.可以说 .NET Core就是这个时代催生的产物.自2016年 .NET Core 1.0 发布以 ...

  7. 2018年1月20日上海MVP线下技术分享会纪实

    1月20日正值大寒节气,在微软MVP朱兴亮的组织牵头下,上海MVP自发举办了题为<跟社区专家一起聊聊混合云.领域驱动.区块链和数字营销>的技术交流会.四名来自上海的MVP分别在自己擅长的技 ...

  8. 成都Uber优步司机奖励政策(4月20日)

    滴快车单单2.5倍,注册地址:http://www.udache.com/ 如何注册Uber司机(全国版最新最详细注册流程)/月入2万/不用抢单:http://www.cnblogs.com/mfry ...

  9. 北京Uber优步司机奖励政策(4月20日)

    滴快车单单2.5倍,注册地址:http://www.udache.com/ 如何注册Uber司机(全国版最新最详细注册流程)/月入2万/不用抢单:http://www.cnblogs.com/mfry ...

随机推荐

  1. bootstrap(响应式)加减输入框

    <div class="row">  <div class="col-lg-6">    <div class="inp ...

  2. 用ElasticSearch搭建自己的搜索和分析引擎

    作者:robben,腾讯高级工程师 商业转载请联系腾讯WeTest获得授权,非商业转载请注明出处. 导语:互联网产品中的检索功能随处可见.当你的项目规模是百度大搜|商搜或者微信公众号搜索这种体量的时候 ...

  3. 生成订单:三个表(Products,Orders,OrderItem)

    1.有三个表(Product上,Orders,OrderItem) 分别创建对应的三个实体类 OrderItem中有外键Order_id 参考Orders中的id :Product_id参考Produ ...

  4. MapReduce处理流程

    MapReduce是Hadoop2.x的一个计算框架,利用分治的思想,将一个计算量很大的作业分给很多个任务,每个任务完成其中的一小部分,然后再将结果合并到一起.将任务分开处理的过程为map阶段,将每个 ...

  5. 纯JS实现图片验证码功能并兼容IE6-8

    最近要搞一个图片验证码功能,但是又不想自己写后台代码.于是自己准备搞一个纯前端的验证码功能,于是网上搜索了一下,找到一个插件gVerify.js,简单好用,实现完美.不过后面接到说要兼容IE8,想想也 ...

  6. JAVA虚拟机环境变量设置

    转自: 网络    下载java环境变量设置所需的jdk并安装,下载地址:http://www.oracle.com/technetwork/cn/java/javase/downloads/jdk7 ...

  7. 蓝桥杯-括号问题-java

    /* (程序头部注释开始) * 程序的版权和版本声明部分 * Copyright (c) 2016, 广州科技贸易职业学院信息工程系学生 * All rights reserved. * 文件名称: ...

  8. Python 基础 四 面向对象杂谈

    Python 基础  四  面向对象杂谈 一.isinstance(obj,cls) 与issubcalss(sub,super) isinstance(obj,cls)检查是否obj是否是类 cls ...

  9. 纯css实现翻牌特效

    大家有没有看到过网上很炫的翻牌效果,牌正面对着我们,然后点击一下,牌就被翻过来了,效果很酷炫,是不是很想知道是怎么实现的么,代码很简单,跟着小编往下走. 先给大家介绍一下翻牌的原理: 1.父容器设置设 ...

  10. java:Comparable比较器

    /*Comparable 是java.lang中的一个接口,所以是默认导入的,不需要显示的导入. *如果你先直接在本类中实现排序,那么可以直接实现该接口(例如:public class Compara ...