Golang | Leetcode Golang题解之第392题判断子序列

题目:

题解:

Go 复制代码
func isSubsequence(s string, t string) bool {
    n, m := len(s), len(t)
    f := make([][26]int, m + 1)
    for i := 0; i < 26; i++ {
        f[m][i] = m
    }
    for i := m - 1; i >= 0; i-- {
        for j := 0; j < 26; j++ {
            if t[i] == byte(j + 'a') {
                f[i][j] = i
            } else {
                f[i][j] = f[i + 1][j]
            }
        }
    }
    add := 0
    for i := 0; i < n; i++ {
        if f[add][int(s[i] - 'a')] == m {
            return false
        }
        add = f[add][int(s[i] - 'a')] + 1
    }
    return true
}
相关推荐
元亓亓亓几秒前
LeetCode热题100--62. 不同路径--中等
算法·leetcode·职场和发展
小白菜又菜16 分钟前
Leetcode 1925. Count Square Sum Triples
算法·leetcode
李迟3 小时前
Golang实践录:使用sqlx操作sqlite3数据库
数据库·golang·sqlite
POLITE33 小时前
Leetcode 41.缺失的第一个正数 JavaScript (Day 7)
javascript·算法·leetcode
POLITE34 小时前
Leetcode 42.接雨水 JavaScript (Day 3)
javascript·算法·leetcode
好易学·数据结构4 小时前
可视化图解算法76:最大子数组和
数据结构·算法·leetcode·面试·动态规划·力扣·笔试
falldeep6 小时前
Pandas入门指南
数据结构·算法·leetcode·pandas
闲看云起6 小时前
Leetcode-day4:从「移动零」到「盛最多水的容器」
数据结构·算法·leetcode·职场和发展
圣保罗的大教堂7 小时前
leetcode 840. 矩阵中的幻方 中等
leetcode