【Python3】【力扣题】392. 判断子序列

news/2024/7/24 5:01:52 标签: leetcode, python

【力扣题】题目描述:

【Python3】代码:

1、解题思路:遍历字符串s,使用一个列表依次记录在字符串t中的位置,若没有该字母则返回False,若索引号小于上一个字母的索引号,返回False。否则返回True。

知识点:[ ]:创建新列表。相当于 list()。

              字符串.find(...):在字符串中查找某元素,返回索引号,没有返回-1。

              列表[-1]:获取列表中最后一个元素。

              列表.append(...):往列表尾部添加一个元素。

python">class Solution:
    def isSubsequence(self, s: str, t: str) -> bool:
        alist = []
        i = -1
        for x in s:
            i = t.find(x,i+1)
            if i == -1: return False
            if alist and i <= alist[-1]:
                return False
            alist.append(i)
        return True

也可以用两个队列分别记录字符串s和t,遍历字符串s,依次从t的队列队头移除一个元素,若与s的字母相同,s的队列队头移除该元素,最终s的队列没有元素,则返回True,否则返回False。

知识点:collections.deque(...):双端队列。左端进,右端出。也可以右端进,左端出。

              队列.popleft():从队列的队头(左端)移除一个元素,并返回该元素。

python">class Solution:
    def isSubsequence(self, s: str, t: str) -> bool:
        from collections import deque
        sdeque, tdeque = deque(s), deque(t)
        for x in s:
            while tdeque:
                if x == tdeque.popleft():
                    sdeque.popleft()
                    break
        return not sdeque

也可以遍历字符串t,依次判断是否与字符串s中的字母相同。若字符串t遍历完,字符串s仍有字母,则返回False,否则返回True。

知识点:字符串[索引]:获取字符串中索引号对应的元素。

              字符串[起始索引 结束索引]:获取字符串中起始索引(含)到结束索引(不含)的元素。

              len(...):获取序列的长度。

python">class Solution:
    def isSubsequence(self, s: str, t: str) -> bool:
        for x in t:
            if s and x == s[0]:
                s = s[1:]
        return not s
        # 或者
        i, n = 0, len(s)
        for x in t:
            if i < n and x == s[i]:
                i += 1
        return i == n

2、解题思路:双指针。两个指针分别指向两个字符串的起始位置,比对两字母是否相同,若相同,同时指向下一个,若不同,只有字符串t的指针指向下一个。若字符串t遍历完,字符串s仍有字母,则返回False,否则返回True。

python">class Solution:
    def isSubsequence(self, s: str, t: str) -> bool:
        i, j = 0, 0
        n, m = len(s), len(t)
        while i < n and j < m:
            if t[j] == s[i]:
                i += 1
            j += 1
        return i == n

3、解题思路:动态规划。

① 获取字符串t的长度m,一个m+1行26列的矩阵(最后一行的内容都为m)。

② 1行对应字符串t的1个元素,26列依次对应26个字母。从后往前遍历字符串t,每一个字母对应的位置记录其在字符串t中的索引号,该行其他列等于下一行该列的内容(例如:字符串t第2个元素为c,则矩阵中行号为1列号为2中内容为1,该行其他列为下一行的内容,注意索引号从0开始)。

③ 遍历字符串s,第一个字母从第一行开始找,字母对应位置中内容若为m,则字符串t中不存在该字母返回False,若不为m,则该位置中内容+1作为下一个字母查找的行号,全部查找完,则返回True。

知识点:ord(...):将字符转为ASCII或者Unicode数值。

python">class Solution:
    def isSubsequence(self, s: str, t: str) -> bool:
        m = len(t)
        f = [[0] * 26 for i in range(m)]
        f.append([m] * 26)
        for i in range(m-1,-1,-1):
            for j in range(26):
                f[i][j] = i if j == ord(t[i]) - ord("a") else f[i+1][j]
        add = 0
        for x in s:
            index = ord(x) - ord("a")
            if f[add][index] == m: return False
            add = f[add][index] + 1
        return True

4、解题思路:迭代器。将字符串t转为迭代器,遍历字符串s,所有字母都在该迭代器中则返回True,否则返回False。

知识点:iter(...):转为迭代器。迭代器中元素只依次访问一次。

              all(...):所有都满足条件,则返回True,否则返回False。

python">class Solution:
    def isSubsequence(self, s: str, t: str) -> bool:
        a = iter(t)
        return all(x in a for x in s)

 5、解题思路:使用正则表达式查找。

知识点:".*".join(s):相当于将字符串s中每个内容中间添加.*。例如:

              re.search(...):使用正则表达式查找某字符串,其中正则表达式".*" 匹配0个或多个任意字符(除了换行符\n)。

                __import__(...):动态加载类和函数。如果一个模块经常变化就可以使用 __import__() 来动态载入。

              bool(...):转为布尔类型,只有True和False。

python">class Solution:
    def isSubsequence(self, s: str, t: str) -> bool:
        return bool(__import__("re").search(".*".join(s), t))
        # 或者
        import re
        res = re.search(".*".join(s), t)
        return bool(res)

 


http://www.niftyadmin.cn/n/5333034.html

相关文章

centos7 arm服务器编译升级安装动态库libstdc++.so.6,解决GLIBC和CXXABI版本低的问题

前言 由于centos7内置的libstdc.so.6版本太低&#xff0c;导致安装第三方包的时候&#xff0c;会报“CXXABI_1.3.8”不存在等问题。 自带的打印如下&#xff1a; strings /usr/lib64/libstdc.so.6 | grep GLIBC strings /usr/lib64/libstdc.so.6 | grep CXXABI 如图 升级 注…

外观模式介绍

目录 一、外观模式介绍 1.1 外观模式定义 1.2 外观模式原理 1.2.1 外观模式类图 1.2.2 模式角色说明 1.2.3 示例代码 二、外观模式的应用 2.1 需求说明 2.2 需求实现 2.2.1 类图 2.2.2 具体实现 2.2.2.1 灯光类 2.2.2.2 电视类 2.2.2.3 空调类 2.2.2.4 外观面板类…

阿里云国外云服务器多少钱?2024年最新价格

阿里云国外服务器优惠活动「全球云服务器精选特惠」&#xff0c;国外服务器租用价格24元一个月起&#xff0c;免备案适合搭建网站&#xff0c;部署独立站等业务场景&#xff0c;阿里云服务器网aliyunfuwuqi.com分享阿里云国外服务器优惠活动&#xff1a; 全球云服务器精选特惠…

Linux 常用的一些命令

目录 一、常用文件管理命令二、tmux 和 vimtmuxvim 三、[Shell语法](https://blog.csdn.net/weixin_43288201/article/details/105643692)四、git五、sshReference 一、常用文件管理命令 (1) ctrl c: 取消命令&#xff0c;并且换行 (2) ctrl u: 清空本行命令 (3) tab键&#x…

亚信安慧AntDB:聚焦执行性能,带给用户前所未有的数据库体验

亚信安慧AntDB数据库是一款国产数据库产品&#xff0c;以其独特之处和出色表现而备受瞩目。它的诞生源于对现实问题的深入思考和实践经验&#xff0c;旨在提供一种高效、稳定、可靠的数据库解决方案。下面将从多个角度介绍AntDB的特点和优势。 首先&#xff0c;AntDB以服务人数…

java基础之线程安全问题以及线程安全集合类

线程安全问题 当多个线程同时访问同一个临界资源时,原子操作可能被破坏,会导致数据丢失, 就会触发线程安全问题 临界资源: 被多个线程同时访问的对象 原子操作: 线程访问临界资源的过程中不可更改和缺失的操作 互斥锁 每个对象都默认拥有互斥锁, 该锁默认不开启. 当开启互斥…

IOS-UIAlertController简单使用-Swift

UIAlertControlle时IOS的对话框控制器&#xff08;警报控制器&#xff09;&#xff0c;简单使用方法如下&#xff1a; 步骤都一样&#xff0c;先是创建UIAlertController&#xff0c;然后创建UIAlertAction&#xff0c;再将UIAlertAction添加到UIAlertController中&#xff0c;…

C++I/O流——(4)格式化输入/输出(第二节)

归纳编程学习的感悟&#xff0c; 记录奋斗路上的点滴&#xff0c; 希望能帮到一样刻苦的你&#xff01; 如有不足欢迎指正&#xff01; 共同学习交流&#xff01; &#x1f30e;欢迎各位→点赞 &#x1f44d; 收藏⭐ 留言​&#x1f4dd; 含泪播种的人一定能含笑收获&#xff…