代码随想录day55

392判断子序列

cpp 复制代码
class Solution {
public:
    bool isSubsequence(string s, string t) 
    {
        vector<vector<int>>dp(s.size()+1,vector<int>(t.size()+1,0));
        int res=0;
        for (int i = 1; i <= s.size(); i++) 
        {
            for(int j=1;j<=t.size();j++)
            {
                if(s[i-1]==t[j-1]) dp[i][j]=dp[i-1][j-1]+1;
                else dp[i][j]=dp[i][j-1];
                res=res>dp[i][j]?res:dp[i][j];
            }
        }
        if(res == s.size()) return true;
        return false;
    }
};

792匹配子序列的单词书

cpp 复制代码
class Solution {
public:
    int numMatchingSubseq(string s, vector<string>& words) 
    {
        vector<vector<int>> index(256);
        for(int i=0;i<s.size();i++)
        {
            char c=s[i];
            index[c].push_back(i);
        }
        int res=0;
        for (string word : words) 
        {
            int i = 0;
            int cur = -1;
            for (; i < word.size(); i++) 
            {
                char c = word[i];
                if (index[c].empty()) 
                {
                    break;
                }
                auto it = upper_bound(index[c].begin(), index[c].end(), cur);
                if (it == index[c].end()) {
                    break;
                }
                // 向前移动指针 j
                cur = *it;
            }
            // 如果 word 完成匹配,则是子序列
            if (i == word.size()) {
                res++;
            }
    }
    return res;
    }
};

115不同的子序列

cpp 复制代码
class Solution {
public:
    int numDistinct(string s, string t) {
        vector<vector<uint64_t>> dp(s.size() + 1, vector<uint64_t>(t.size() + 1));
        for (int i = 0; i < s.size(); i++) dp[i][0] = 1;
        for (int j = 1; j < t.size(); j++) dp[0][j] = 0;
        for (int i = 1; i <= s.size(); i++) 
        {
            for (int j = 1; j <= t.size(); j++) 
            {
                if (s[i - 1] == t[j - 1]) 
                {
                    dp[i][j] = dp[i - 1][j - 1] + dp[i - 1][j];
                } 
                else {
                    dp[i][j] = dp[i - 1][j];
                }
            }
        }
        return dp[s.size()][t.size()];
    }
};
相关推荐
aigcapi9 小时前
RAG 系统的黑盒测试:从算法对齐视角解析 GEO 优化的技术指标体系
大数据·人工智能·算法
苏宸啊10 小时前
链式二叉树基操代码实现&OJ题目
数据结构
风筝在晴天搁浅10 小时前
hot100 25.K个一组翻转链表
数据结构·链表
柯慕灵10 小时前
7大推荐系统/算法框架对比
算法·推荐算法
adam-liu10 小时前
Fun Audio Chat 论文+项目调研
算法·语音端到端·fun-audio-chat
小十一再加一11 小时前
【初阶数据结构】栈和队列
数据结构
栀秋66611 小时前
你会先找行还是直接拍平?两种二分策略你Pick哪个?
前端·javascript·算法
.魚肉11 小时前
旅行商问题 (TSP)的蛮力算法与动态规划算法(Held-Karp)
动态规划·算法设计与分析·tsp·旅行商问题·蛮力法·held-karp算法·复杂度求解
如果你想拥有什么先让自己配得上拥有11 小时前
数学思想和数学思维分别都有什么?
线性代数·算法·机器学习
长安er12 小时前
LeetCode136/169/75/31/287 算法技巧题核心笔记
数据结构·算法·leetcode·链表·双指针