LeetCode392_判断子序列

  • 标签:#双指针 #字符串 #动态规划
    • Ⅰ. 题目
    • Ⅱ. 示例
  • 0. 个人方法
  • 官方题解一:双指针
  • 官方题解二:动态规划

标签:#双指针 #字符串 #动态规划

Ⅰ. 题目

给定字符串 s 和 t ,判断 s 是否为 t 的子序列。

字符串的一个子序列是原始字符串删除一些(也可以不删除)字符而不改变剩余字符相对位置形成的新字符串。(例如,"ace"是"abcde"的一个子序列,而"aec"不是)。

  • 进阶:
    如果有大量输入的 S,称作 S1, S2, … , Sk 其中 k >= 10亿,你需要依次检查它们是否为 T 的子序列。在这种情况下,你会怎样改变代码?

Ⅱ. 示例

· 示例 1:
输入:s = “abc”, t = “ahbgdc”
输出:true

· 示例 2:
输入:s = “axc”, t = “ahbgdc”
输出:false

0. 个人方法

遍历字符串 t,逐个和 s 字符串对比,如果相同就让cnt++(我的代码里写的是 position),不同就继续遍历字符串 t,如果 cnt == s.length(),那么就说明字符串 t 中有字符串 s 这个子序列

class Solution {
public:bool isSubsequence(string s, string t) {if (t.length() < s.length())return false;if (t.length() == 0 && s.length() == 0)return true;int position = 0;for (int i=0; i<t.length(); ++i){if (t[i] == s[position]){position++;}if (position == s.length()){return true;}}return false;}
};

官方题解一:双指针

大致思路与个人方法相同

class Solution {
public:bool isSubsequence(string s, string t) {int n = s.length(), m = t.length();int i = 0, j = 0;while (i < n && j < m) {if (s[i] == t[j]) {i++;}j++;}return i == n;}
};

官方题解二:动态规划

(如果需要多次查询 s 是否是 t 的子序列,DP方法更高效)

考虑到前面双指针的做法,我们注意到我们有大量的时间用于在 t 中找到下一个匹配字符。
因此,我们可以考虑对 t 进行预处理,记录从当前位置起,往后每一个字符第一次出现的位置。

class Solution {
public:bool isSubsequence(string s, string t) {int n = s.size(), m = t.size();// DP 表:f[i][j] 表示 t 从位置 i 开始,字符 j 第一次出现的位置vector<vector<int>> f(m + 1, vector<int>(26, 0));// 初始化边界:如果 t 的末尾之后的位置,所有字符都不可达(设为 m)for (int j = 0; j < 26; j++) {f[m][j] = m;}// 填充 DP 表for (int i = m - 1; i >= 0; i--) {for (int j = 0; j < 26; j++) {if (t[i] == j + 'a')  // 当前字符匹配f[i][j] = i;else                  // 否则继承 i+1 的结果f[i][j] = f[i + 1][j];}}// 遍历 s,检查是否能在 t 中找到匹配的字符int add = 0;  // 当前在 t 中的查找起始位置for (int i = 0; i < n; i++) {if (f[add][s[i] - 'a'] == m) {  // 字符 s[i] 在 t 中不存在return false;}add = f[add][s[i] - 'a'] + 1;  // 跳到匹配位置的下一个位置}return true;  // 所有字符都匹配成功}
};
  • 示例1:

    • 输入:s = “abc”, t = “ahbgdc”

      • 预处理 t 后,f 会记录每个字符的位置。

      • 匹配 s:

        • ‘a’ 在 t 的位置 0 → add = 1

        • ‘b’ 在 t 的位置 2 → add = 3

        • ‘c’ 在 t 的位置 5 → 匹配成功

    • 输出:true

  • 示例2:

    • 输入:s = “axc”, t = “ahbgdc”

      • ‘a’ 匹配 t[0] → add = 1

      • ‘x’ 在 t 中不存在 → 返回 false

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如若转载,请注明出处:http://www.pswp.cn/pingmian/78882.shtml
繁体地址,请注明出处:http://hk.pswp.cn/pingmian/78882.shtml
英文地址,请注明出处:http://en.pswp.cn/pingmian/78882.shtml

如若内容造成侵权/违法违规/事实不符,请联系英文站点网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

Python匿名函数与内置函数较难与较冷门知识点考前速记

5 lambda匿名函数与Python内置函数 lambda 函数通常用于编写简单的、单行的函数,通常在需要函数作为参数传递的情况下使用,例如在 map()、filter()、sorted()、list.sort() 等函数与方法中。 lambda语法格式: lambda arguments: expression lambda是 Python 的关键字,用…

DeepSeek谈《凤凰项目 一个IT运维的传奇故事》

《凤凰项目&#xff1a;一个IT运维的传奇故事》&#xff08;The Phoenix Project: A Novel About IT, DevOps, and Helping Your Business Win&#xff09;是Gene Kim、Kevin Behr和George Spafford合著的一部小说&#xff0c;通过虚构的故事生动展现了IT运维中的核心挑战和Dev…

【上海大学数据库原理实验报告】MySQL基础操作

实验目的 熟悉MySQL基础操作。 实验内容 创建四张工程项目的关系表。 图 1 四张工程项目关系表的结构 检索供应零件编号为J1的工程的供应商编号SNO。检索供应零件给工程J1&#xff0c;且零件编号为P1的供应商编号SNO。查询没有正余额的工程编号、名称及城市&#xff0c;结果…

winget使用

Get-Command winget winget search qq winget install Tencent.QQ.NT

逻辑回归在信用卡欺诈检测中的实战应用

在大数据和机器学习蓬勃发展的时代&#xff0c;信用卡欺诈检测成为了保障金融安全的重要环节。逻辑回归作为一种经典的机器学习算法&#xff0c;在这一领域发挥着关键作用。本文将通过一段完整的Python代码&#xff0c;详细解析逻辑回归在信用卡欺诈检测中的具体应用过程&#…

矫平机:金属板材精密加工的“整形专家”

一、矫平机的定义与核心功能 矫平机&#xff08;Leveling Machine&#xff09;是金属加工领域的关键设备&#xff0c;主要用于消除金属板材或带材在轧制、运输过程中产生的内应力&#xff0c;矫正其弯曲、扭曲、波浪边等形变缺陷&#xff0c;使材料达到毫米级甚至微米级的平整…

百度「心响」:通用超级智能体,重新定义AI任务执行新范式

在AI技术从“对话交互”迈向“任务执行”的转折点&#xff0c;百度于2025年4月正式推出移动端超级智能体应用——心响。这款以“AI任务完成引擎”为核心的创新产品&#xff0c;被誉为“AI指挥官”&#xff0c;通过自然语言交互实现复杂任务的全流程托管&#xff0c;覆盖知识解析…

游戏性能测试

1. 分阶段&#xff0c;看目的&#xff0c;确定高中低三档测试机&#xff0c;最低档机的确定需要和客户端主程和制作人等共同确定 确定三档机的方式&#xff1a; 1. 要上线地区的top100&#xff0c;根据用户占比&#xff0c;划分出三档 2. 根据用研部门提供的数据&#xff0c;确…

react-10样式模块化(./index.module.css, <div className={welcome.title}>Welcome</div>)

1.react样式模块化 避免各个组件类名相同 相关样式冲突所以需要样式模块化。比如在组件Hello中的样式引入&#xff0c;将样式文件名更改为index.module.css如下图。 2. 文件中引入模块以及使用 文件中import引入模块样式 import welcome from "./index.module.css"…

4月30日星期三今日早报简报微语报早读

4月30日星期三&#xff0c;农历四月初三&#xff0c;早报#微语早读。 1、神舟十九号载人飞船因东风着陆场气象原因推迟返回&#xff1b; 2、林毅夫&#xff1a;到2049年中国经济体量有望达到美国的两倍&#xff1b; 3、市场监管总局&#xff1a;2024年查办商标、专利等领域违…

小刚说C语言刷题—1462小明的游泳时间

1.题目描述 伦敦奥运会要到了&#xff0c;小明在拼命练习游泳准备参加游泳比赛。 这一天&#xff0c;小明给自己的游泳时间做了精确的计时&#xff08;本题中的计时都按 24 小时制计算&#xff09;&#xff0c;它发现自己从 a 时 b 分一直游泳到当天的 c 时 d 分。 请你帮小…

SpringBoot+EasyExcel+Mybatis+H2实现导入

文章目录 SpringBootEasyExcelMybatisH2实现导入1.准备工作1.1 依赖管理1.2 配置信息properties1.3 H2数据库1.4 Spring Boot 基础概念1.5 Mybatis核心概念 1.6 EasyExcel核心概念 2.生成Excel数据工具类-随机字符串编写生成Excel的java文件 3.导入功能并且存入数据库3.1 返回结…

嵌入式开发高频面试题全解析:从基础编程到内存操作核心知识点实战

一、数组操作&#xff1a;3x3 数组的对角和、偶数和、奇数和 题目 求 3x3 数组的对角元素和、偶数元素和、奇数元素和。 知识点 数组遍历&#xff1a;通过双重循环访问数组的每个元素&#xff0c;外层循环控制行&#xff0c;内层循环控制列。对角元素判断&#xff1a; 主对…

分布式优化与一致性算法python实现

目录 摘要一、分布式优化问题描述二、一致性算法基础2.1 平均一致性(Average Consensus)2.2 Gossip 协议三、分布式梯度下降(DGD)四、分布式 ADMM 与共识优化五、收敛性与参数选择六、典型案例6.1 传感器网络参数估计6.1.1 问题描述6.1.2 算法设计6.1.3 实验结果6.2 分布式…

突破SQL注入字符转义的实战指南:绕过技巧与防御策略

在渗透测试中&#xff0c;SQL注入始终是Web安全的重点攻击手段。然而&#xff0c;当开发者对用户输入的特殊字符&#xff08;如单引号、反斜杠&#xff09;进行转义时&#xff0c;传统的注入方式往往会失效。本文将深入探讨如何绕过字符转义限制&#xff0c;并给出防御建议。 目…

算法导论第6章思考题

6.3-2 func(A) 1 A.heap-sizeA.len 2 \quad for i ⌊ A . l e n 2 ⌋ \lfloor {A.len\over2}\rfloor ⌊2A.len​⌋ downto 1 3 \qquad MAX-HEAPIFY(A,i) 对于第2行的循环控制变量i来说&#xff0c;为啥要求它是从 ⌊ A . l e n 2 ⌋ \lfloor {A.len\over2}\rfloor ⌊2A.len​⌋…

可商用,可离线运行,可API接口调用的开源AI数字人项目Heygem,喂饭级安装教程

前言 Heygem 是一款开源项目&#xff0c;致力于发挥你电脑硬件的全部潜力&#xff0c;让你无需依赖云端&#xff0c;也能在本地高效运行各类开源AI数字人模型。无论是 AI 语音对话、虚拟主播&#xff0c;还是数字人驱动引擎&#xff0c;Heygem 通过底层性能调度与资源管理优化&…

三个概念:DataBinding,Dependency Property 与DataTemplate

WPF 核心概念详解&#xff1a;DataBinding、Dependency Property 和 DataTemplate 1. DataBinding (数据绑定) 基本概念 DataBinding 是 WPF 的核心机制&#xff0c;用于在 UI 元素和数据源之间建立自动同步关系。 关键特性 双向绑定&#xff1a;数据变化自动反映到 UI&…

C语言教程(二十六):C 语言内存管理详解

一、C 语言内存区域划分 在 C 语言程序运行时,内存主要分为以下几个区域: 1.1 栈区(Stack) 特点:由编译器自动分配和释放,主要存储函数的局部变量、函数参数、返回地址等。栈区的内存分配和释放是按照后进先出(LIFO)的原则进行的,速度快。示例: #include <stdio.…

腾讯云服务器性能提升全栈指南(2025版)

腾讯云服务器性能提升全栈指南&#xff08;2025版&#xff09; 一、硬件选型与资源优化 1. 实例规格精准匹配 腾讯云服务器提供计算型CVM、内存型MEM、大数据型Hadoop等12种实例类型。根据业务特性选择&#xff1a; • 高并发Web应用&#xff1a;推荐SA3实例&#xff0…