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

最长公共子序列(二)

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
};
全部评论

相关推荐

03-17 16:55
已编辑
广东工业大学 Web前端
他们都管我叫八股王:个人技能可以放最下面,项目描述点可以不用这么多,把可以被狠狠拷打的点尽量弄的再显眼一些,自己讲不出来的也尽量不要写
听劝,我这个简历该怎么改...
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

更多
正在热议
更多
# 春招至今,你的战绩如何? #
10315次浏览 92人参与
# 你的实习产出是真实的还是包装的? #
1836次浏览 42人参与
# 米连集团26产品管培生项目 #
5892次浏览 215人参与
# 军工所铁饭碗 vs 互联网高薪资,你会选谁 #
7537次浏览 43人参与
# 简历第一个项目做什么 #
31643次浏览 333人参与
# 重来一次,我还会选择这个专业吗 #
433423次浏览 3926人参与
# MiniMax求职进展汇总 #
23968次浏览 308人参与
# 当下环境,你会继续卷互联网,还是看其他行业机会 #
187071次浏览 1122人参与
# 牛客AI文生图 #
21418次浏览 238人参与
# 不考虑薪资和职业,你最想做什么工作呢? #
152338次浏览 887人参与
# 研究所笔面经互助 #
118892次浏览 577人参与
# 简历中的项目经历要怎么写? #
310182次浏览 4202人参与
# AI时代,哪些岗位最容易被淘汰 #
63576次浏览 813人参与
# 面试紧张时你会有什么表现? #
30502次浏览 188人参与
# 你今年的平均薪资是多少? #
213063次浏览 1039人参与
# 你怎么看待AI面试 #
179990次浏览 1245人参与
# 高学历就一定能找到好工作吗? #
64323次浏览 620人参与
# 你最满意的offer薪资是哪家公司? #
76474次浏览 374人参与
# 我的求职精神状态 #
448028次浏览 3129人参与
# 正在春招的你,也参与了去年秋招吗? #
363346次浏览 2638人参与
# 腾讯音乐求职进展汇总 #
160627次浏览 1111人参与
# 校招笔试 #
470762次浏览 2964人参与
牛客网
牛客网在线编程
牛客网题解
牛客企业服务