leetcode 115. 不同的子序列 golang


本文摘自网络,作者,侵删。

  1. 不同的子序列

思路

动态规划

dp[i][j]表示S前i个字符 中 T前j个字符的个数。

则有如下递推公式

如果 s[i]==t[j] dp[i][j] = dp[i-1][j-1]+ dp[i-1][j],

否则 dp[i][j]=dp[i-1][j].

另外还有quickpath: 如果s的长度比t小一定为0. 所以可以快速返回

代码

func numDistinct(s string, t string) int {
   if len(s) < len(t) {
        return 0
    }
    s = "#" + s
    t = "#" + t
    dp := make([][]int, len(t))
    for i := 0; i < len(t); i++ {
        dp[i] = make([]int, len(s))
    }
    dp[0][0] = 1
    for j := 0; j < len(s); j++ {
        dp[0][j] = 1
    }
    for i := 1; i < len(t); i++ {
        dp[i][0] = 1
        if t[i] == s[i] {
            dp[i][i] = dp[i-1][i-1]
        }
        for j := i + 1; j < len(s); j++ {
            dp[i][j] = dp[i][j-1]
            if t[i] == s[j] {
                dp[i][j] += dp[i-1][j-1]
            }
        }
    }
    return dp[len(t)-1][len(s)-1]
}

本文来自:简书

感谢作者:lucasgao

查看原文:leetcode 115. 不同的子序列 golang

相关阅读 >>

etcd包导入坑

Go语言如何把int转为字符串

再见Go-micro!企业项目迁移Go-zero全攻略(一)

Golang如何对excel进行处理

Golang连接elasticsearch

手撸Golang 基本数据结构与算法 图的最短路径  狄克斯特拉算法

Golang 冒泡排序

关于Golang slice的append扩容

Go设计模式之工厂模式浅谈

手撸Golang 架构设计原则 单一职责原则

更多相关阅读请进入《Go》频道 >>




打赏

取消

感谢您的支持,我会继续努力的!

扫码支持
扫码打赏,您说多少就多少

打开支付宝扫一扫,即可进行扫码打赏哦

分享从这里开始,精彩与您同在

评论

管理员已关闭评论功能...