【LeetCode】005.Longest Palindromic Substring - javascript解法

程序应该没有问题,提交不能AC,主要的原因是超时。最好的时候,达到85个案例,还有几个案例未能测试。本地测试未通过案例,均可以。可能是我使用对象而非数组来作为动态规划的容器,导致开销过大。目前结合前面用Javascript刷LeetCode发现,在 javascript 中,乘除操作比较耗时,for循环能少则少。后面还会注意不同操作的耗时、性能情况。

先给出最化结构的版本,很短:

var longestPalindrome = function(s) {
   var p = {0:{}};
    var result = [0,0];
    for(var i = 0; i<s.length; i++){
        p[i] == undefined? p[i] = {}:p[i+1] ={};
        p[i][i] = p[i+1][i] = true;
    }
    for(var i = 1; i<s.length; i++){
        for(var j = 0; j < s.length  - i; j++){
            p[j][j+i] = p[j+1][j+i-1] && (s[j] == s[j+i]);
            if( p[j][j+i] && i > result[0]){result[0] = i,result[1] = j;}
        }
    }
    return s.substr(result[1],result[0]+1);
};

中间版本:

var longestPalindrome = function(s) {
   var p = {0:{}};
    var result = [0,0,0]
    // 初始化
    for(var i = 0; i<s.length; i++){
        p[i] == undefined? p[i] = {}:p[i+1] ={};
        // console.log(p[i],p[i+1])
        p[i][i] = true;
        p[i+1][i] = true;// 这一步很关键,只是用于初始化
    }
    for(var i = 1; i<s.length; i++){
        for(var j = 0; j < s.length  - i; j++){
            p[j][j+i] = p[j+1][j+i-1] && (s[j] == s[j+i]);
            // console.log(j,j+i,p[j+1][j+i-1],s[j] == s[j+i])
        }
    }

    for(var i in p){
        for(var j in p[i]){
            if(p[i][j]){
                 j-i > result[0]?(result[0] = j-i,result[1] = i,result[2] = j):(null); 
            }
            // console.log(i,j,p[i][j])
        }
    }
    // console.log(result);
    return s.substr(result[1],result[0]+1);
};
// 优化版本
var longestPalindrome = function(s) {
   var p = {0:{}};
    var result = [0,0];

    // 初始化
    for(var i = 0; i<s.length; i++){
        p[i] == undefined? p[i] = {}:p[i+1] ={};
        // console.log(p[i],p[i+1])
        p[i][i] = true;
        p[i+1][i] = true;// 这一步很关键,只是用于初始化
    }
    for(var i = 1; i<s.length; i++){
        for(var j = 0; j < s.length - i; j++){
            p[j][j+i] = p[j+1][j+i-1] && (s[j] == s[j+i]);
            p[j][j+i] && i > result[0]?(result[0] = i,result[1] = j):(null);
        }
    }
    return s.substr(result[1],result[0]+1);
};
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 2
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值