Leetcode打卡:字符串及其反转中是否存在同一子字符串

执行结果:通过

题目 3083 字符串及其反转中是否存在同一子字符串

给你一个字符串 s ,请你判断字符串 s 是否存在一个长度为 2 的子字符串,在其反转后的字符串中也出现。

如果存在这样的子字符串,返回 true;如果不存在,返回 false

示例 1:

**输入:**s = "leetcode"

**输出:**true

解释: 子字符串 "ee" 的长度为 2,它也出现在 reverse(s) == "edocteel" 中。

示例 2:

**输入:**s = "abcba"

**输出:**true

解释: 所有长度为 2 的子字符串 "ab""bc""cb""ba" 也都出现在 reverse(s) == "abcba" 中。

示例 3:

**输入:**s = "abcd"

**输出:**false

解释: 字符串 s 中不存在满足「在其反转后的字符串中也出现」且长度为 2 的子字符串。

提示:

  • 1 <= s.length <= 100
  • 字符串 s 仅由小写英文字母组成。

代码以及解题思路:

代码

复制代码
class Solution:
    def isSubstringPresent(self, s: str) -> bool:
        st = {(a, b) for a, b in pairwise(s[::-1])}
        return any((a, b) in st for a, b in pairwise(s))

解题思路:

  1. 反转字符串并生成字符对 :首先,将字符串 s 反转,然后使用 pairwise 函数(这个函数通常来自 itertools 模块,但在代码中没有直接给出,其作用是生成一个序列中相邻元素的二元组)生成反转字符串中相邻字符的二元组集合 st。例如,如果 s = "abc",则反转后为 "cba",生成的二元组集合为 {('c', 'b'), ('b', 'a')}

  2. 检查原字符串中的连续字符对 :接着,使用 pairwise 函数生成原字符串 s 中相邻字符的二元组,并检查这些二元组是否存在于之前生成的集合 st 中。

  3. 判断是否存在符合条件的子串 :如果原字符串中的任何一个连续字符对在反转字符串生成的字符对集合 st 中存在,那么说明可以通过删除一些字符(即不在这个字符对中的字符),使得剩下的字符能够按照原字符串中的某种非连续顺序重新排列成 s 的一个连续子串。此时,函数返回 True

  4. 返回结果 :如果遍历完所有原字符串中的连续字符对后,没有找到任何一个在集合 st 中的字符对,那么说明不存在这样的子串,函数返回 False

相关推荐
_下雨天.13 分钟前
LVS负载均衡
服务器·负载均衡·lvs
小成202303202653 小时前
Linux高级02
linux·开发语言
mounter6253 小时前
【硬核前沿】CXL 深度解析:重塑数据中心架构的“高速公路”,Linux 内核如何应对挑战?-- CXL 协议详解与 LSF/MM 最新动态
linux·服务器·网络·架构·kernel
++==3 小时前
Linux 进程间通信与线程同步技术详解:IPC 机制、线程 API、同步工具与经典同步问题
linux
特长腿特长3 小时前
centos、ubantu系列机的用户和用户组的结构是什么?具体怎么配置?用户组权限怎么使用?这篇文章持续更新,帮助你复习linux的基础知识
linux·运维·centos
zzzyyy5383 小时前
Linux环境变量
linux·运维·服务器
pluvium274 小时前
记对 xonsh shell 的使用, 脚本编写, 迁移及调优
linux·python·shell·xonsh
无级程序员4 小时前
centos7 安装 llvm-toolset-7-clang出错的问题解决
linux·centos
kebeiovo4 小时前
atomic原子操作实现无锁队列
服务器·c++
6Hzlia4 小时前
【Hot 100 刷题计划】 LeetCode 48. 旋转图像 | C++ 矩阵变换题解
c++·leetcode·矩阵