leecode5 最长回文子串

举报
兔老大 发表于 2021/04/22 00:51:05 2021/04/22
【摘要】 给定一个字符串 s,找到 s 中最长的回文子串。你可以假设 s 的最大长度为 1000。 示例 1: 输入: "babad" 输出: "bab" 注意: "aba" 也是一个有效答案。 示例 2: 输入: "cbbd" 输出: "bb" 思路: 马拉车算法,不会的翻我博客的最早的文章。 只是要记录一下答案是在哪个中心取到的,方便取串。 class So...

给定一个字符串 s,找到 s 中最长的回文子串。你可以假设 s 的最大长度为 1000。

示例 1:

输入: "babad"
输出: "bab"
注意: "aba" 也是一个有效答案。
示例 2:

输入: "cbbd"
输出: "bb"

思路:

马拉车算法,不会的翻我博客的最早的文章。

只是要记录一下答案是在哪个中心取到的,方便取串。


  
  1. class Solution {
  2. public char[] manacherString(String str) {
  3. char[] charArr = str.toCharArray();
  4. char[] res = new char[str.length() * 2 + 1];
  5. int index = 0;
  6. for (int i = 0; i != res.length; i++) {
  7. res[i] = (i & 1) == 0 ? '#' : charArr[index++];
  8. }
  9. return res;
  10. }
  11. public int[] maxLcpsLength(String str) {
  12. if (str == null || str.length() == 0) {
  13. return new int[2];
  14. }
  15. char[] charArr = manacherString(str);
  16. int[] pArr = new int[charArr.length];
  17. int index = -1;
  18. int pR = -1;
  19. int ansIndex=-1;
  20. int max = Integer.MIN_VALUE;
  21. for (int i = 0; i != charArr.length; i++) {
  22. pArr[i] = pR > i ? Math.min(pArr[2 * index - i], pR - i) : 1;
  23. while (i + pArr[i] < charArr.length && i - pArr[i] > -1) {
  24. if (charArr[i + pArr[i]] == charArr[i - pArr[i]])
  25. pArr[i]++;
  26. else {
  27. break;
  28. }
  29. }
  30. if (i + pArr[i] > pR) {
  31. pR = i + pArr[i];
  32. index = i;
  33. }
  34. if(max<pArr[i]) {
  35. max=pArr[i];
  36. ansIndex=i;
  37. }
  38. max = Math.max(max, pArr[i]);
  39. }
  40. int[] ans=new int[2];
  41. ans[0]=max-1;
  42. ans[1]=ansIndex;
  43. return ans;
  44. }
  45. public String longestPalindrome(String s) {
  46. int[] ans=maxLcpsLength(s);
  47. return s.substring((ans[1]-ans[0])/2,(ans[1]+ans[0])/2+(ans[1]+ans[0])%2);
  48. }
  49. }

 

文章来源: fantianzuo.blog.csdn.net,作者:兔老大RabbitMQ,版权归原作者所有,如需转载,请联系作者。

原文链接:fantianzuo.blog.csdn.net/article/details/103249571

【版权声明】本文为华为云社区用户转载文章,如果您发现本社区中有涉嫌抄袭的内容,欢迎发送邮件进行举报,并提供相关证据,一经查实,本社区将立刻删除涉嫌侵权内容,举报邮箱: cloudbbs@huaweicloud.com
  • 点赞
  • 收藏
  • 关注作者

评论(0

0/1000
抱歉,系统识别当前为高风险访问,暂不支持该操作

全部回复

上滑加载中

设置昵称

在此一键设置昵称,即可参与社区互动!

*长度不超过10个汉字或20个英文字符,设置后3个月内不可修改。

*长度不超过10个汉字或20个英文字符,设置后3个月内不可修改。