[C国演义] 第二十三章

这篇具有很好参考价值的文章主要介绍了[C国演义] 第二十三章。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

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

力扣链接
[C国演义] 第二十三章,刷题录,c++,动态规划,leetcode,数据结构,算法
求 删除字符的ASCLL和的最小值 ⇒ 正难则反求公共子序列的ASCLL和的最大值

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

  • 转态转移方程 — 根据最后一个位置进行讨论
    [C国演义] 第二十三章,刷题录,c++,动态规划,leetcode,数据结构,算法

  • 遍历顺序
    [C国演义] 第二十三章,刷题录,c++,动态规划,leetcode,数据结构,算法

  • 初始化
    需要使用左上角的情况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;
    }
};

[C国演义] 第二十三章,刷题录,c++,动态规划,leetcode,数据结构,算法


最长重复子数组

力扣链接
[C国演义] 第二十三章,刷题录,c++,动态规划,leetcode,数据结构,算法

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

  • 状态转移方程
    [C国演义] 第二十三章,刷题录,c++,动态规划,leetcode,数据结构,算法

  • 遍历顺序
    [C国演义] 第二十三章,刷题录,c++,动态规划,leetcode,数据结构,算法

  • 初始化
    需要使用左上角的情况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;
    }
};

[C国演义] 第二十三章,刷题录,c++,动态规划,leetcode,数据结构,算法


云锁断崖无觅处,半山松竹撼秋风. —— 岳飞文章来源地址https://www.toymoban.com/news/detail-766068.html

到了这里,关于[C国演义] 第二十三章的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • ChatGPT 与生成式 AI 的崛起:第二十六章到第三十三章

    原文:Rise of Generative AI and ChatGPT 译者:飞龙 协议:CC BY-NC-SA 4.0 恐怖分子、罪犯、警察、国防、执法机构、工程师、作家和学生等都在使用 ChatGPT,这是来自 OpenAI 的强大自然语言人工智能工具,作为他们日常工作的重要组成部分。自去年 11 月底发布以来,这种生成式人工智

    2024年01月24日
    浏览(256)
  • [C国演义] 第十三章

    力扣链接 根据题目要求: 返回的数对应的下标各不相同 三个数之和等于0 不可包含重复的三元组 – – 即 顺序是不做要求的 如: [-1 0 1] 和 [0, 1, -1] 是同一个三元组 输出答案顺序不做要求 暴力解法: 排序 + 3个for循环 + 去重 — — N^3, 肯定超时 优化: 排序 + 双指针 + 去重 — —

    2024年02月08日
    浏览(39)
  • 【LeetCode 75】第二十三题(2352)相等行列对

    目录 题目: 示例: 分析: 代码+运行结果: 题目很简洁,就是要我们寻找行与列相同的对数。相同行与列不仅是要元素相同,还需要顺序也一样(难度变小了,如果不要求顺序一样的话,还需要单独统计元素以及出现次数,会稍微麻烦一点) 一般要寻找相同的数的时候,我

    2024年02月13日
    浏览(35)
  • 【正点原子STM32连载】第二十三章 高级定时器互补输出带死区控制实验 摘自【正点原子】APM32F407最小系统板使用指南

    本章将介绍使用APM32F407输出带死区和刹车控制的两路互补PWM。通过本章的学习,读者将学习到高级定时器的互补输出、死区插入和刹车的功能的使用。 本章分为如下几个小节: 23.1 硬件设计 23.2 程序设计 23.3下载验证 23.1 硬件设计 23.1.1 例程功能 定时器8通道1及其互补通道输

    2024年02月09日
    浏览(61)
  • 算法与数据结构(二十三)动态规划设计:最长递增子序列

    注:此文只在个人总结 labuladong 动态规划框架,仅限于学习交流,版权归原作者所有; 也许有读者看了前文 动态规划详解,学会了动态规划的套路:找到了问题的「状态」,明确了 dp 数组/函数的含义,定义了 base case;但是不知道如何确定「选择」,也就是找不到状态转移

    2024年02月13日
    浏览(38)
  • 【正点原子FPGA连载】第二十三章PS通过VDMA驱动LCD显示实验 摘自【正点原子】DFZU2EG_4EV MPSoC之嵌入式Vitis开发指南

    1)实验平台:正点原子MPSoC开发板 2)平台购买地址:https://detail.tmall.com/item.htm?id=692450874670 3)全套实验源码+手册+视频下载地址: http://www.openedv.com/thread-340252-1-1.html AXI VDMA是Xilinx专门针对视频应用提供的一种高带宽的解决方案,旨在实现AXI4-Stream视频接口和AXI4接口之间的高

    2024年02月04日
    浏览(63)
  • 【第二十五课】动态规划:完全背包问题(acwing-3 / 公式推导 / 思路理解 / 优化 / c++代码)

    目录 思路 朴素代码 优化 公式推导上  二维代码  一维代码 公式理解上   在开始看完全背包问题之前,可能需要先了解01背包及其解决办法。 指路👇 【第二十五课】动态规划:01背包问题(acwing-2 / 思路 / 含一维数组优化 / c++代码) 这个问题和01背包的区别就是 每件物品可以

    2024年03月19日
    浏览(62)
  • 蓝桥杯刷题第二十三天

    题目描述 小明有一块空地,他将这块空地划分为 n 行 m 列的小块,每行和每列的长度都为 1。 小明选了其中的一些小块空地,种上了草,其他小块仍然保持是空地。 这些草长得很快,每个月,草都会向外长出一些,如果一个小块种了草,则它将向自己的上、下、左、右四小

    2023年04月22日
    浏览(44)
  • 第二十三回:Flutter中的事件处理

    我们在上一章回中介绍了对齐和边距类Widget相关的内容,,本章回中将介绍 事件处理相关的知识 .闲话休提,让我们一起Talk Flutter吧。 我们在这里说的事件表示点击和滑动屏幕时触发的事件,类似Android中的TouchEvent.Flutter提供了 PointerEvent 类及其子类来封装不同类型的事件。同

    2024年02月02日
    浏览(35)
  • 二十三种设计模式第二十篇--备忘录模式

    备忘录模式,备忘录模式属于行为型模式。它允许在不破坏封装的情况下捕获和恢复对象的内部状态。 保存一个对象的某个状态,以便在适当的时候恢复对象,该模式通过创建一个备忘录对象来保存原始对象的状态,并将其存储在一个负责管理备忘录的负责人对象中。 备忘

    2024年02月14日
    浏览(38)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包