题解 | #最长公共子序列(二)#

最长公共子序列(二)

http://www.nowcoder.com/practice/6d29638c85bb4ffd80c020fe244baf11

 * longest common subsequence
 * @param s1 string字符串 the string
 * @param s2 string字符串 the string
 * @return string字符串
 */
function LCS( s1 ,  s2 ) {
    // write code here
    let sum=''
    let res2=[]
    if(s1.length==0||s2.length==0){return -1;}
    for(let i=0;i<=s2.length;i++){
        let res=[]
        for(let j=0;j<=s1.length;j++){
            if(i==0){res.push(0)}
            else{
                if(j==0){res.push(0)}
                else{
                    if(s1[j-1]==s2[i-1]){
                        res.push(Math.min(res[j-1],res2[i-1][j])+1)
                    }////////min!!!!!!!!
                    //构建矩阵时,想要加,取小的加一
                    else{
                        res.push(Math.max(res[j-1],res2[i-1][j]))
                        //不加时保存大的
                     }
               }
            }
        }
        res2.push(res)
    }
    let m=s2.length
    let n=s1.length
    let ss=res2[s2.length][s1.length]
    for(let i=0;i<ss;i++){
    //从后往前,确保都取得到
        while(res2[m][n]==ss-i){
            while(res2[m][n]==ss-i){
            m--;
            }
            m++;
            while(res2[m][n]==ss-i){
            n--;
            }
            sum=sum+s2[m-1]
        }
        m--;
    }
    let sum2=''
    for(let i=0;i<sum.length;i++){
        sum2=sum2+sum[sum.length-1-i]
    }
    if(sum2.length==0){return -1}
   else{return sum2}
}
module.exports = {
    LCS : LCS
};
全部评论

相关推荐

点赞 评论 收藏
分享
不愿透露姓名的神秘牛友
07-02 14:45
bg是二本双一流硕,目标是Java后端开发岗,投暑期实习0大厂面试,只有极少的大厂测开,可能投的晚加上简历太烂加上0实习?求大佬们给个建议
程序员小白条:别去小厂,初创或者外包,尽量去中小,100-499和500-999,专门做互联网产品的,有公司自研的平台和封装的工具等等,去学习一些业务相关的,比如抽奖,积分兑换,SSO认证,风控,零售等等,目标 Java 后端开发吗?你要不考虑直接走大厂测开?如果技术不行的话,有面试你也很难过的
实习,不懂就问
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

更多
牛客网
牛客网在线编程
牛客网题解
牛客企业服务