当前位置: 首页 > ds >正文

华为OD-2024年E卷-增强的strstr[100分] -- python

问题描述:

C语言有一个库函数:char*strstr(const char *haystack, const char *needle),实现在字符haystack 中查找第一次出现字符串needle的位置,如果未找到则返回null。现要求实现一个strstr的增强函数,可以使用带可选段的字符串来模糊查询,与strstr一样返回首次查找到的字符串位置。可选段使用“[]”标识,表示该位置是可选段中任意一个字符即可满足匹配条件。比如“a[bc]”表示可以匹配“ab"或“ac”。注意目标字符串中可选段可能出现多次。
输入描述
与strstr函数一样,输入参数是两个字符串指针,分别是源字符串和目标字符串。
输出描述
与strstr函数不同,返回的是源字符串中,匹配子字符串相对于源字符串地址的偏移(从0开始算),如果没有匹配返回-1。
补充说明
源字符串中必定不包含[';目标字符串中叮必定成对出现,且不会出现嵌套。输入的字符串长度在[1,100]之间。

abcd
b[cd]
1

解题思路:

将目标字符串按 [] 拆分为所有可能的字符串,遍历源字符串,输出最先匹配的索引,否则输出-1

拆分:

  1. 使用列表 l 记录所有可能的目标字符串,初始化为空: ''
  2. 在 [ 之前:给列表 l 中所有元素分别加上当前字符
  3. 在 ] 之前(即 [] 内):对列表 l 中所有元素与 [] 内字符作笛卡尔积

结束条件:

  1. 当前字符索引 < 目标字符长度
  2. 目标字符串总是以 [ 之前作为结束

代码实现:

s = input()
t = input()
l = []
l.append('')
i = 0
while i < len(t):# [之前,给每个字符串都加上当前字符while i < len(t) and t[i] != '[':for j in range(len(l)):l[j] += t[i]i += 1i += 1# [ 的下一个if i >= len(t):# [ 之前,可能作为结束条件break# ] 之前,给每个字符串分别与[]内每个字符作笛卡尔积tem = []while i < len(t) and t[i] != ']':for j in l:j += t[i]tem.append(j)i += 1l = tem i += 1# ] 的下一个
print(l)
f = True
for test in l:for i in range(len(s)):if s[i:i+(len(test))] == test:f = Falseprint(i)break
if f:print(-1)

http://www.xdnf.cn/news/14644.html

相关文章:

  • OC-UI学习-Auto Layout使用
  • 自主学习-《Absolute Zero: Reinforced Self-play Reasoning with Zero Data》
  • 《贵州安顺棒垒球》国家队运动员·棒球1号位
  • 器件(九)—对设计的模块进行双脉冲仿真
  • 【系统分析师】2011年真题:案例分析-答案及详解
  • 阿里云OSS任意文件写入/删除漏洞修复方案
  • LDPC码的译码算法
  • 一个包含两款主题的社交APP客户端UI解决方案
  • houdini 简单流体模拟 学习笔记
  • OpenKylin安装dotnet及其永久环境配置
  • Redis windows版安装,启动配置【kaki学习备忘录】
  • 基于RSSI的室内定位的排列不变Transformer神经架构
  • 如何在 Elementary OS 上安装 Cinnamon 桌面环境
  • HTTP协议简易入门
  • Spring AOP
  • csv文档批量转换xlsx,xls文档(带界面)
  • Go语言同步原语与数据竞争:数据竞争的检测工具
  • 2011-2020年各省互联网接入端口数数据
  • 打卡day54
  • AC-MT
  • C语言常用库函数
  • LangChain面试内容整理-知识点14:工具包(Toolkits)与用法
  • 生成对抗网络(GANs)入门介绍指南:让AI学会“创造“的魔法(二)【深入版】
  • Textacy:Python 中的文本数据清理和规范化简介
  • 自我实现的量子隐喻:在可能性场域中动态拓展涌现节点
  • LLMs:《WebDancer: Towards Autonomous Information Seeking Agency》翻译与解读
  • 02-Timer0-Timer1-Timer2-Timer3-Timer4测试程序
  • Sa-Token全面深入学习指南
  • 【慧游鲁博】【15】后台管理系统功能完善:仪表盘、多模态交互日志、简单问答词条管理
  • 建造者模式Builder Pattern