码农知识堂 - 1000bd
  •   Python
  •   PHP
  •   JS/TS
  •   JAVA
  •   C/C++
  •   C#
  •   GO
  •   Kotlin
  •   Swift
  • 【LeetCode】最长公共子序列(动态规划)


    1143. 最长公共子序列 - 力扣(LeetCode)

    一、题目

    给定两个字符串 text1 和 text2,返回这两个字符串的最长 公共子序列 的长度。如果不存在 公共子序列 ,返回 0 。

    一个字符串的 子序列 是指这样一个新的字符串:它是由原字符串在不改变字符的相对顺序的情况下删除某些字符(也可以不删除任何字符)后组成的新字符串。

    例如,"ace" 是 "abcde" 的子序列,但 "aec" 不是 "abcde" 的子序列。
    两个字符串的 公共子序列 是这两个字符串所共同拥有的子序列。

    示例 1:

    输入:text1 = "abcde", text2 = "ace" 
    输出:3  
    解释:最长公共子序列是 "ace" ,它的长度为 3 。

    示例 2:​​​​​​​

    输入:text1 = "abc", text2 = "abc"
    输出:3
    解释:最长公共子序列是 "abc" ,它的长度为 3 。

    示例 3:​​​​​​​

    输入:text1 = "abc", text2 = "def"
    输出:0
    解释:两个字符串没有公共子序列,返回 0 。

    提示:

    • 1 <= text1.length, text2.length <= 1000
    • text1 和 text2 仅由小写英文字符组成。

    二、代码

    1. class Solution {
    2. public int longestCommonSubsequence(String text1, String text2) {
    3. if (text1 == null || text1.length() == 0 || text2 == null || text2.length() == 0) {
    4. return 0;
    5. }
    6. char[] str1 = text1.toCharArray();
    7. char[] str2 = text2.toCharArray();
    8. int[][] dp = new int[str1.length][str2.length];
    9. dp[0][0] = str1[0] == str2[0] ? 1 : 0;
    10. for (int j = 1; j < str2.length; j++) {
    11. dp[0][j] = str1[0] == str2[j] ? 1 : dp[0][j - 1];
    12. }
    13. for (int i = 1; i < str1.length; i++) {
    14. dp[i][0] = str1[i] == str2[0] ? 1 : dp[i - 1][0];
    15. }
    16. for (int i = 1; i < str1.length; i++) {
    17. for (int j = 1; j < str2.length; j++) {
    18. int p1 = dp[i - 1][j];
    19. int p2 = dp[i][j - 1];
    20. int p3 = str1[i] == str2[j] ? dp[i - 1][j - 1] + 1 : dp[i - 1][j - 1];
    21. dp[i][j] = Math.max(p1, Math.max(p2, p3));
    22. }
    23. }
    24. return dp[str1.length - 1][str2.length - 1];
    25. }
    26. }
  • 相关阅读:
    java毕业设计单车管理系统Mybatis+系统+数据库+调试部署
    Redis 高可用及持久化
    使用LiME收集主机物理内存的内容时发生宕机
    自动驾驶感知算法实战2——车载相机及图像处理
    git远程仓库限额的解决方法——大文件瘦身
    【Database System Concept 7th】Chapter 2读书笔记
    【MySQL】基本查询(三)聚合函数+group by
    计算机组成原理——存储器1-20
    JS:构造函数
    chatGPT培训老师AIGC培训讲师叶梓:大模型这么火,我们在使用时应该关注些什么?-6
  • 原文地址:https://blog.csdn.net/cy973071263/article/details/126083925
  • 最新文章
  • 攻防演习之三天拿下官网站群
    数据安全治理学习——前期安全规划和安全管理体系建设
    企业安全 | 企业内一次钓鱼演练准备过程
    内网渗透测试 | Kerberos协议及其部分攻击手法
    0day的产生 | 不懂代码的"代码审计"
    安装scrcpy-client模块av模块异常,环境问题解决方案
    leetcode hot100【LeetCode 279. 完全平方数】java实现
    OpenWrt下安装Mosquitto
    AnatoMask论文汇总
    【AI日记】24.11.01 LangChain、openai api和github copilot
  • 热门文章
  • 十款代码表白小特效 一个比一个浪漫 赶紧收藏起来吧!!!
    奉劝各位学弟学妹们,该打造你的技术影响力了!
    五年了,我在 CSDN 的两个一百万。
    Java俄罗斯方块,老程序员花了一个周末,连接中学年代!
    面试官都震惊,你这网络基础可以啊!
    你真的会用百度吗?我不信 — 那些不为人知的搜索引擎语法
    心情不好的时候,用 Python 画棵樱花树送给自己吧
    通宵一晚做出来的一款类似CS的第一人称射击游戏Demo!原来做游戏也不是很难,连憨憨学妹都学会了!
    13 万字 C 语言从入门到精通保姆级教程2021 年版
    10行代码集2000张美女图,Python爬虫120例,再上征途
Copyright © 2022 侵权请联系2656653265@qq.com    京ICP备2022015340号-1
正则表达式工具 cron表达式工具 密码生成工具

京公网安备 11010502049817号