当前位置: 首页 > article >正文

[C国演义] 第二十三章

第二十三章

  • 两个字符串的最小ASCLL删除和
  • 最长重复子数组

两个字符串的最小ASCLL删除和

力扣链接

求 删除字符的ASCLL和的最小值 ⇒ 正难则反求公共子序列的ASCLL和的最大值

  • 两个数组的dp问题 ⇒ 分区间讨论dp[i][j] -- nums1数组的[0, i] 区间 和 nums2数组的[0, j] 区间, 公共子序列的ASCLL和的最大值

  • 转态转移方程 — 根据最后一个位置进行讨论

  • 遍历顺序

  • 初始化
    需要使用左上角的情况dp表可以多开一行, 多开一列
    但是dp表中使用原 nums1 和 nums2的情况就会出现偏差, 解决方法

    1. 访问nums1 和 nums2里面的情况, 就要 -1
    2. 可以在nums1, nums2前面添加一个 空格使得dp表中的下标 和 nums1 和 nums2中的下标一致化

    ⇒ 这样初始化就方便很多 , 都初始化为 0

  • 返回值— dp[i][j] -- nums1中的[0, i] 区间 以及 nums2中的 [0, j]区间内的所有子序列的组合中, 公共子序列的最大长度返回 两个数组和 - 2 * dp[m][n]

class Solution {
public:
    int minimumDeleteSum(string s1, string s2) 
    {
        int m = s1.size();
        int n = s2.size();

        vector<vector<int>> dp(m+1, vector<int>(n+1));

        int sum = 0;
        for(auto e : s1)  sum += e;
        for(auto e : s2)  sum += e;
        
        for(int i = 1; i <=  m; i++)
        {
            for(int j = 1; j <= n; j++)
            {
                if(s1[i-1]  == s2[j-1])
                {
                    dp[i][j]  = dp[i-1][j-1] + s1[i-1];
                }
                else
                {
                    dp[i][j] = max(dp[i-1][j], dp[i][j-1]);
                }
            }
        }

        int res  = sum - 2 * dp[m][n];

        return res;
    }
};


最长重复子数组

力扣链接

  • 两个1数组的dp问题(子数组) — 每个数组的结束位置进行讨论dp[i][j] -- nums1数组中以nums1[i]结尾的子数组中 和 nums2数组中以nums2[j]结尾的子数组中, 公共子数组的最长长度

  • 状态转移方程

  • 遍历顺序

  • 初始化
    需要使用左上角的情况dp表可以多开一行, 多开一列
    但是dp表中使用原 nums1 和 nums2的情况就会出现偏差, 解决方法

    1. 访问nums1 和 nums2里面的情况, 就要 -1
    2. 可以在nums1, nums2前面添加一个 空格使得dp表中的下标 和 nums1 和 nums2中的下标一致化

    ⇒ 这样初始化就方便很多 , 都初始化为 0

  • 返回结果 — 返回dp表中的最大值

class Solution {
public:
    int findLength(vector<int>& nums1, vector<int>& nums2) 
    {
        int m = nums1.size();
        int n = nums2.size();

        vector<vector<int>> dp(m+1, vector<int>(n+1));

        int res = 0;
        for(int i = 1; i <= m; i++)
        {
            for(int j = 1; j <= n; j++)
            {
                if(nums1[i-1] == nums2[j-1])
                {
                    dp[i][j] = dp[i-1][j-1] + 1;
                }

                res = max(res, dp[i][j]);
            }
        }

        return res;
    }
};


云锁断崖无觅处,半山松竹撼秋风. —— 岳飞


http://www.kler.cn/a/156695.html

相关文章:

  • Linux——GPIO输入输出裸机实验
  • 设计模式之工厂模式,但是宝可梦
  • 使用elementUI实现表格行拖拽改变顺序,无需引入外部库
  • C++,STL 054(24.11.13)
  • ❤React-React 组件通讯
  • 网络安全-蓝队基础
  • SpringBoot + Spring Cloud Alibaba + Nacos实现服务管理
  • Qt 网络通信
  • 【JavaEE】单例模式
  • 使用ESP8266驱动TFT显示屏
  • html/css中用float实现的盒子案例
  • virtualbox上win7企业微信CPU高问题
  • 企业微信协议开发,API接口调用
  • 大数据基础设施搭建 - 数据装载
  • C++ 系列 第五篇 C++ 算术运算符及类型转换
  • ClickHouse入门手册1.0
  • GO基础之变量与常量
  • 专业课:递归非递归中序遍历
  • LeetCode [中等] 二叉树中序—二叉搜索树中第K小的元素
  • 【wvp】测试记录
  • 百度收录批量查询工具,免费SEO优化排名工具
  • 【有ISSN、ISBN号!往届均已完成EI检索】第三届电子信息工程、大数据与计算机技术国际学术会议(EIBDCT 2024)
  • Java BIO、NIO、AIO 有什么区别?
  • git merge和git rebase
  • 原生input实现上传文件
  • Java | 数据一致性校验遇到的时间序列化格式不一致问题如何解决?