LeetCode392:判断子序列

题目链接:392. 判断子序列 - 力扣(LeetCode)

代码如下:

复制代码
class Solution {
public:
    bool isSubsequence(string s, string t) {
        int len1 = s.size();
        int len2 = t.size();
        int result = 0;
        vector<vector<int> > dp(len1 + 1, vector<int>(len2 + 1, 0));
        for(int i = 1; i <= len1; i++)
        {
            for(int j = 1; j <= len2; j++)
            {
                if(s[i - 1] == t[j - 1])
                {
                    dp[i][j] = dp[i - 1][j - 1] + 1;
                }
                else
                {
                    dp[i][j] = max(dp[i - 1][j], dp[i][j - 1]);
                }
                if(dp[i][j] > result)
                {
                    result = dp[i][j];
                }
            }
        }

        if(result == len1)
        {
            return true;
        }
        return false;
    }
};

这个判断自序列其实就是和之前的判断公共,重复子序列一样,就只是返回的值不一样,思路完全一模一样

类型题详细介绍:LeetCode718:最长重复子数组-CSDN博客

LeetCode1035:1035. 不相交的线 - 力扣(LeetCode)

这个题目其实和不相交的线也是一样的,不相交的线其实都可以转换为这个公共子序列问题来编写

这都是一系列问题

相关推荐
cpp_25017 分钟前
P1873 [COCI 2011/2012 #5] EKO / 砍树
数据结构·c++·算法·题解·二分答案·洛谷·csp
啊哦呃咦唔鱼9 分钟前
leetcodehot100-347. 前 K 个高频元素
数据结构·算法·leetcode
玛丽莲茼蒿10 分钟前
Leetcode hot100 多数元素【简单】
算法·leetcode·职场和发展
AbandonForce11 分钟前
Map类:pair键值对|map的基本操作|operator[]
开发语言·c++·算法·leetcode
澈20713 分钟前
C++核心:封装与static静态成员实战指南
开发语言·c++·算法
田梓燊17 分钟前
力扣:146.LRU 缓存
算法·leetcode·缓存
_深海凉_23 分钟前
LeetCode热题100-杨辉三角
算法·leetcode·职场和发展
小O的算法实验室34 分钟前
2025年SEVC,面向进化计算的学习注入式优化,深度解析+性能实测
算法·论文复现·智能算法·智能算法改进
handler0134 分钟前
进程状态流转的本质:Linux 内核队列与底层数据结构解密
linux·运维·c语言·数据结构·c++·笔记·学习
啊我不会诶43 分钟前
2024北京市赛补题
c++·算法