zoukankan      html  css  js  c++  java
  • leetcode5.最长回文子串

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

    示例 1:

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

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

    我的思路是考虑两种情况,1)中间为一个数字,左右关于那个数字对称,总数为奇数2)中间的数字也一样,总数为偶数个,但是这两种情况中又要考虑原sooos这种情况,算法不是很优,我的解法为:

    class Solution {
        public String longestPalindrome(String s) {
           int i, count = 1, p = 1, t;
           int length = s.length();
           boolean flag = false;
           if(length > 0) {
               if (length == 1) return s;
               else if (length > 1) {
                   char[] str = s.toCharArray();
                   if (length == 2) return str[0] == str[1] ? s : String.valueOf(str[0]);
                   else {
                       for (i = 1; i < length; i++) {
                           if (str[i] == str[i - 1]) {
                               if(i != length - 1) {
                                   if (str[i] == str[i + 1]) {
                                       if( i == 1 )t = 3;
                                       else {
                                           int x = isSymmetry(str, i - 2, i + 1);
                                           int y = isSymmetry(str, i - 1, i + 1);
                                           t = x > y?x:y;
                                       }
                                   } else t = i == 1 ? 2 : isSymmetry(str, i - 2, i + 1);
                               }else t = 2;
                               if (count < t) {
                                   flag = true;
                                   p = i;
                                   count = t;
                               }
                           } else {
                                t = isSymmetry(str, i - 1, i + 1);
                                if(count < t){
                                    flag = false;
                                    p = i;
                                    count = t;
                                }
                           }
                       }
                       if (flag) return count%2 == 0?s.substring(p - count / 2, p + count / 2):s.substring(p - count / 2, p +1+ count / 2);
                       else return s.substring(p - count / 2, p +1+ count / 2);
                   }
               }
           }
           return null;
        }
        public static int isSymmetry(char[] str, int m, int n){
            int temp = n - m - 1, t;
            if(m >= 0 && n < str.length){
                if(str[m] == str[n]){
                    m = m - 1;
                    n = n + 1;
                    t = isSymmetry(str, m, n);
                    return temp > t? temp:t;
                }
            }
            return temp;
        }
    }
    我在黑板墙看到一种不用考虑奇偶的情况,先统计中间相同的数字,然后左右再考虑是否对称:该算法为:
    class Solution {
        public String longestPalindrome(String s) {
            if (s == null || s.length() == 0) {
                return "";
            }
    //         保存起始位置,测试了用数组似乎能比全局变量稍快一点
            int[] range = new int[2];
            char[] str = s.toCharArray();
            for (int i = 0; i < s.length(); i++) {
    //             把回文看成中间的部分全是同一字符,左右部分相对称
    //             找到下一个与当前字符不同的字符
                i = findLongest(str, i, range);
            }
            return s.substring(range[0], range[1] + 1);
        }
        
        public static int findLongest(char[] str, int low, int[] range) {
    //         查找中间部分
            int high = low;
            while (high < str.length - 1 && str[high + 1] == str[low]) {
                high++;
            }
    //         定位中间部分的最后一个字符
            int ans = high;
    //         从中间向左右扩散
            while (low > 0 && high < str.length - 1 && str[low - 1] == str[high + 1]) {
                low--;
                high++;
            }
    //         记录最大长度
            if (high - low > range[1] - range[0]) {
                range[0] = low;
                range[1] = high;
            }
            return ans;
        }
    }
    该算法更为简洁,且运行速度更快!果然人外有人,天外有天!,学到了,学到了
  • 相关阅读:
    OpenStack源码系列---neutron-server
    理解全虚拟、半虚拟以及硬件辅助的虚拟化
    QEMU+GDB调试方法
    SQL Server故障转移集群
    OpenStack源码系列---nova-conductor
    mysql 安装和基本使用
    数据库原理
    linux 计划任务
    linux 进程管理和内存分配

  • 原文地址:https://www.cnblogs.com/hddandelion/p/13799203.html
Copyright © 2011-2022 走看看