【代码随想录】【算法训练营】【第51天】 [115]不同的子序列 [583]两个字符串的删除操作 [72]编辑距离

前言

思路及算法思维,指路 代码随想录。
题目来自 LeetCode。

day 51,周四,又是不能坚持的一天~

题目详情

[115] 不同的子序列

题目描述

115 不同的子序列
115 不同的子序列

解题思路

前提:转换为t为s的子序列的个数,元素的相对顺序一致
思路:动态规划 动态规划 dp[i][j]: 字符串s以i - 1为结尾的[0, i - 1] 中出现 字符串t以j - 1为结尾的[0, j - 1]中的个数,s[i-1] == t[j-1]时, dp[i][j] = dp[i-1][j-1] + dp[i-1][j];s[i-1] != t[j-1]时, dp[i][j] = dp[i-1][j]
重点:递推公式的推导、dp数组初始化

代码实现

C语言
动态规划

用例超出int, long long int数值范围,使用unsigned long long类型

// 动态规划 dp[i][j]: 字符串s以i - 1为结尾的[0, i - 1] 中出现 字符串t以j - 1为结尾的[0, j - 1]中的个数
// s[i-1] == t[j-1]时, dp[i][j] = dp[i-1][j-1] + dp[i-1][j]
// s[i-1] != t[j-1]时, dp[i][j] = dp[i-1][j]

int numDistinct(char* s, char* t) {
    int sLen = strlen(s);
    int tLen = strlen(t);
    unsigned long long dp[sLen + 1][tLen + 1];
    // dp初始化
    for (int m = 0; m <= sLen; m++) {
        dp[m][0] = 1;
    }
    for (int n = 1; n <= tLen; n++) {
        dp[0][n] = 0;
    }
    // 循环
    for (int i = 1; i <= sLen; i++) {
        for (int j =1; j <= tLen; 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[sLen][tLen];
}

[583] 两个字符串的删除操作

题目描述

583 两个字符串的删除操作
583 两个字符串的删除操作

解题思路

前提:转化为 删除word1中与word2的公共子序列(元素相对位置不变)之外的字符 的问题 (两个单词均可以删除)
思路:动态规划 dp[i][j]: 以i-1下标为结尾的单词word1和以j-1下标为结尾的单词word2,使其相同所需的最小步数(删除次数),word1[i-1] == word2[j-1]时, dp[i][j] = dp[i-1][j-1];word1[j-1] != word2[j-1]时, 分为3种情况, dp[i][j] = min(dp[i-1][j-1]+2, dp[i-1][j]+1, dp[i][j-1]+1),因为dp[i][j-1] = dp[i-1][j-1]+1,所以可简化为 dp[i][j] = min(dp[i][j-1]+1, dp[i-1][j]+1)
重点:递推公式的推导、dp数组初始化

代码实现

C语言
动态规划
// 转化为 删除word1中与word2的公共子序列(元素相对位置不变)之外的字符 的问题 (两个单词均可以删除)
// 动态规划 dp[i][j]: 以i-1下标为结尾的单词word1和以j-1下标为结尾的单词word2,使其相同所需的最小步数(删除次数)
// word1[i-1] == word2[j-1]时, dp[i][j] = dp[i-1][j-1]
// word1[j-1] != word2[j-1]时, 分为3种情况, dp[i][j] = min(dp[i-1][j-1]+2, dp[i-1][j]+1, dp[i][j-1]+1)
// 因为dp[i][j-1] = dp[i-1][j-1]+1,所以可简化为 dp[i][j] = min(dp[i][j-1]+1, dp[i-1][j]+1)

int minFun(int p1, int p2)
{
    return p1 < p2 ? p1 : p2;
}

int minDistance(char* word1, char* word2) {
    int word1_len = strlen(word1);
    int word2_len = strlen(word2);
    int dp[word1_len + 1][word2_len + 1];
    // dp初始化
    for (int m = 0; m <= word1_len; m++) {
        dp[m][0] = m;
    }
    for (int n = 1; n <= word2_len; n++) {
        dp[0][n] = n;
    }
    // 遍历
    for (int i = 1; i <= word1_len; i++) {
        for (int j = 1; j <= word2_len; j++) {
            if (word1[i - 1] == word2[j - 1]) {
                dp[i][j] = dp[i - 1][j - 1];
            } else {
                dp[i][j] = minFun(dp[i - 1][j] + 1, dp[i][j - 1] + 1);
            }
        }
    }
    return dp[word1_len][word2_len];
}

[72] 编辑距离

题目描述

72 编辑距离
72 编辑距离

解题思路

前提:通过增删改的操作,使得两个单词相同 (两个单词均可修改)
思路:动态规划 dp[i][j]: 以i-1下标为结尾的单词word1和以j-1下标为结尾的单词word2,使其相同所需的最小操作数(增删改), word1[i-1] == word2[j-1]时, dp[i][j] = dp[i-1][j-1], word1[j-1] != word2[j-1]时, 分为3种情况[增加word1(相当于删除word2)/删除/word1/修改word1],dp[i][j] = min(dp[i][j-1]+1, dp[i-1][j]+1, dp[i-1][j-1]+1)
重点:递推公式的推导、dp数组初始化

代码实现

C语言
动态规划
// 动态规划 dp[i][j]: 以i-1下标为结尾的单词word1和以j-1下标为结尾的单词word2,使其相同所需的最小操作数(增删改)
// word1[i-1] == word2[j-1]时, dp[i][j] = dp[i-1][j-1]
// word1[j-1] != word2[j-1]时, 分为3种情况[增加word1(相当于删除word2)/删除/word1/修改word1]
// dp[i][j] = min(dp[i][j-1]+1, dp[i-1][j]+1, dp[i-1][j-1]+1)

int minFun(int p1, int p2)
{
    return p1 < p2 ? p1 : p2;
}

int minDistance(char* word1, char* word2) {
    int word1_len = strlen(word1);
    int word2_len = strlen(word2);
    int dp[word1_len + 1][word2_len + 1];
    // dp初始化
    for (int m = 0; m <= word1_len; m++) {
        dp[m][0] = m;
    }
    for (int n = 1; n <= word2_len; n++) {
        dp[0][n] = n;
    }
    // 遍历
    for (int i = 1; i <= word1_len; i++) {
        for (int j = 1; j <= word2_len; j++) {
            if (word1[i - 1] == word2[j - 1]) {
                dp[i][j] = dp[i - 1][j - 1];
            } else {
                dp[i][j] = minFun(dp[i - 1][j - 1] + 1, minFun(dp[i - 1][j] + 1, dp[i][j - 1] + 1));
            }
        }
    }
    return dp[word1_len][word2_len];
}

今日收获

  1. 动态规划

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:/a/771846.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

flask项目部署总结

这个部署的时候要用虚拟环境&#xff0c;cd进项目文件夹 python3 -m venv myenv source myenv/bin/activate激活 之后就安装一些库包之类的&#xff0c;&#xff08;flask&#xff0c;requests,bs4,等等&#xff09; 最重要的是要写.flaskenv文件并且pip install 一个能运行…

【MySQL】InnoDB的存储结构

InnoDB的存储结构&#xff1a;每个表都会生成一个表空间文件&#xff0c;这个文件里面最小结构就是行&#xff0c;存储的真正的数据&#xff0c;一个页来管理若干行&#xff0c;一个区来管理若干页&#xff0c;一个区组来管理若干区。段并不是真正的物理存储结构&#xff0c;它…

计组期末复习

本内容是我在计组期末复习时的记录&#xff0c;可能对你的复习帮助不大。下面是我复习时看的一些资料和视频&#xff1a; 知识体系&#xff1a; 【【计算机组成原理】计算机组成原理期末考试速成课&#xff0c;不挂科&#xff01;&#xff01;】https://www.bilibili.com/video…

轻松跨越国界:使用WildCard畅享全球AI服务

大家好&#xff0c;现在AI技术已经深入到我们的日常生活中。然而&#xff0c;许多朋友仍然难以获取优质的AI工具和应用。那么&#xff0c;如何才能使用像ChatGPT这样的AI服务呢&#xff1f; 今天我为大家介绍一个“一劳永逸”的解决方案&#xff0c;它就是我们的主角——WildC…

spdlog一个非常好用的C++日志库(四): 源码分析之logger类

目录 1.简介 2.类图关系 3.logger数据成员 4.logger函数成员 4.1.构造与析构 4.1.1.构造函数 4.1.2.拷贝构造、移动构造 4.2.交换操作 4.3.log()记录日志消息 4.3.1.格式串 4.3.2.普通字符串 4.3.3.日志级别 4.3.4.宽字符支持 4.4.sink_it_&#xff1a;将log消息…

【内网渗透】从0到1的内网渗透基础概念笔记

目录 域 域的介绍 单域 父域和子域 域树 域森林 域名服务器 活动目录 活动目录介绍 域内权限 组 域本地组 全局组 通用组 总结 示例 A-G-DL-P策略 重要的域本地组 重要的全局组、通用组 安全域划分 域 域的介绍 Windows域是计算机网络的一种形式&#xf…

币界网讯,预计以太坊现货 ETF 将于 7 月中旬推出

刚刚 ETF Store 总裁 Nate Geraci 在 X &#xff08;前Twitter&#xff09;平台上宣布&#xff0c;备受数字货币市场期待的SEC以太坊现货 ETF提案&#xff0c;将于7 月中旬通过美国证券交易委员会&#xff08;SEC&#xff09;批准。Nate Geraci透露修订后的 S-1 文件将于 7 月 …

艺活网DIY手工制作网站源码 工艺制作教程平台源码,带数据

帝国CMS仿《手艺活》DIY手工制作网源码&#xff0c;仿手艺活自适应手机版模板。 带数据库和图片资源&#xff0c;一共5个G大小&#xff0c;下载需耐心。 92开发 手艺活网DIY手工制作网站源码 创意手工艺品制作教程平台系统帝国h5自适应手机端 是一套展示各种 DIY 小物品精美又…

初学Spring之自动装配 Bean

Bean 的作用域&#xff1a; 1.单例模式&#xff08;Spring 默认机制&#xff09; scope“singleton” 2.原型模式&#xff1a;每次从容器中 get 时&#xff0c;都会产生一个新对象 scope"prototype" 3. request、session、application&#xff0c;只能在 web 开…

webp2jpg网页在线图片格式转换源码

源码介绍 webp2jpg-免费在线图片格式转化器, 可将jpeg、jpg、png、gif、 webp、svg、ico、bmp文件转化为jpeg、png、webp、webp动画、gif文件。 无需上传文件&#xff0c;本地即可完成转换! 源码特点&#xff1a; 无需上传&#xff0c;使用浏览器自身进行转换批量转换输出we…

九、函数的声明和定义

函数声明&#xff1a; 1. 告诉编译器有一个函数叫什么&#xff0c;参数是什么&#xff0c;返回类型是什么。但是具体是不是存在&#xff0c;函数 声明决定不了。 2. 函数的声明一般出现在函数的使用之前。要满足先声明后使用。 3. 函数的声明一般要放在头文件中的。 定义的函…

视频监控平台web客户端的免密查看视频页:在PC浏览器上如何调试手机上的前端网页(PC上的手机浏览器的开发者工具)

目录 一、手机上做前端页面开发调试 1、背景 2、视频监控平台AS-V1000的视频分享页 3、调试手机前端页面代码的条件 二、手机端的准备工作 1、手机准备 2、手机的开发者模式 3、PC和手机的连接 &#xff08;1&#xff09;进入调试模式 &#xff08;2&#xff09;选择…

期权开户零门槛怎么操作?期权不满50w的开户方式

今天带你了解期权开户零门槛怎么操作&#xff1f;期权不满50w的开户方式。在股票期权市场上&#xff0c;期权交易是一种非常受欢迎的投资方式。它不仅可以增加投资组合的多样性&#xff0c;还可以为投资者提供一定的保护和利润机会&#xff0c;比如通过买入认股期权做空对冲大盘…

基于Springboot的智慧信息化机房管理系统

1 项目介绍 1.1 研究目的和意义 随着社会的快速发展&#xff0c;计算机的影响是全面且深入的。人们生活水平的不断提高&#xff0c;日常生活中人们对高校共享机房管理方面的要求也在不断提高&#xff0c;需要高校共享机房的人数更是不断增加&#xff0c;使得高校共享机房管理…

Swift Core Data 分阶段迁移

文章目录 前言什么是分阶段迁移&#xff1f;提供一些背景信息创建迁移管理器设置使用 Core Data 栈。总结 前言 在这之前&#xff0c;我发布了一篇文章&#xff0c;在其中解释了如何使用映射模型和自定义迁移策略执行复杂的 Core Data 迁移。虽然这种方法性能良好且运行良好&a…

阿里巴巴矢量图标库使用

阿里巴巴矢量图标库官网 添加图标到购物车 悬浮到图标上面会有个购物车icon,点击一下就可以添加购物车了 添加图标到项目 添加完购物车后,右上角会有当前在购物车的数量,点击右上角购物车icon,在新弹窗内点击添加至项目,选择添加到哪个项目(没有项目就创建一个),点击完成,…

C++ 教程 - 08 文件操作与异常处理

文章目录 文件操作文件对象其他方法异常处理 文件操作 需要头文件 <iostream><fstream> 读取文件 ifstream obj; obj.open(const char* filename, std::in)写入文件ofstream obj; obj.open(const char* filename, std::out)读、写文件 fstream&#xff0c;包含了i…

免杀笔记 ---> PE

本来是想先把Shellcode Loader给更新了的&#xff0c;但是涉及到一些PE相关的知识&#xff0c;所以就先把PE给更了&#xff0c;后面再把Shellcode Loader 给补上。 声明&#xff1a;本文章内容来自于B站小甲鱼 1.PE的结构 首先我们要讲一个PE文件&#xff0c;就得知道它的结构…

MySQL之备份与恢复(四)

备份与恢复 存储引擎和一致性 3.复制 从备库中备份最大的好处是可以不干扰主库&#xff0c;避免在主库上增加额外的负载。这是一个建立备库的好理由&#xff0c;即使不需要用它做负载均衡或高可用。如果钱是个问题&#xff0c;也可以把备份用的备库用于其他用户&#xff0c;…

​香橙派AIpro测评:usb鱼眼摄像头的Camera图像获取

一、前言 近期收到了一块受到业界人士关注的开发板"香橙派AIpro",因为这块板子具有极高的性价比&#xff0c;同时还可以兼容ubuntu、安卓等多种操作系统&#xff0c;今天博主便要在一块832g的香橙派AI香橙派AIpro进行YoloV5s算法的部署并使用一个外接的鱼眼USB摄像头…