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. PT20150801隆重开班

    PT20150801隆重开班 伴随着秋天的的脚步,带着对梦想的憧憬,POPTEST1508期学员步入正式学习阶段:POPTEST的课程内容吸收了互联网公司先进技术的特点,同时坚持深入浅出的教育特点,完 ...

  2. 华为C8812E 手机logcat不出日志解决方案

    最近在弄Android,使用的测试机为华为C8812E,无论如何也打印不出来日志,在网上搜索了一圈,尝试了很久终于解决了,留作备忘. 华为手机logcat不出日志解决方案 进入拨号界面输入:*#*#2 ...

  3. python作业设计:输入用户名密码,认证成功后显示欢迎信息,输错三次后锁定

    作业需求: 1.输入用户名密码 2.认证成功后显示欢迎信息 3.输错三次后锁定实现思路: 1.判断用户是否在黑名单,如果在黑名单提示账号锁定. 2.判断用户是否存在,如果不存在提示账号不存在. 3.判 ...

  4. 原生态JS实现banner图的常用所有功能

    虽然,用jQuery实现banner图的各种效果十分简单快捷,但是我今天用css+js代码实现了几个banner图的常用功能,效果还不错. 此次,主要想实现以下功能: 1. banner图循环不间断切 ...

  5. oracle备份与还原(导入导出)

    Oracle数据导入导出imp/exp 功能:Oracle数据导入导出imp/exp相当于oracle数据还原与备份.说明:大多情况都可以用Oracle数据导入导出完成数据的备份和还原(不会造成数据的 ...

  6. JS中substring与substr的区别

    Substring: 该方法可以有一个参数也可以有两个参数. (1)  一个参数: 示例: var str=“Olive”: str.substring(3); 结果:“ve” 说明:当substri ...

  7. [原创] JavaScript实现简单的颜色类标签云

    效果预览: 源码分享: <!DOCTYPE html><html><head lang="en"> <meta charset=" ...

  8. C# 弱引用WeakReferance

    在应用程序代码内实例化一个类或结构时,只要有代码引用它,就会形成强引用.例如,如果有一个类MyClass(),并创建一个变量MyClassVariable来引用该类的对象,那么只要在 MyClassV ...

  9. Linux--shell脚本之文本处理工具

    文本处理工具--grep.sed.awk Bash Shell提供了功能强大的文件处理工具:sed(流编辑器stream editor)和awk,都可使用正则表达式进行模式匹配. 而grep又有助于理 ...

  10. seajs加载angularjs

    angularjs是自动完成模块的控制的,而seajs加载模块是异步的,所以不做修改,直接seajs加载angularjs会出错.            在这里讲下自己的解决方法 一.需要把ng-ap ...