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

华为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.dtcms.com/a/252070.html

相关文章:

  • 通过 BLE 和 Wi-Fi 交换优化基于 ID 的远程无人机通信的延迟
  • ubuntu 22.04 安装部署logstash 7.10.0详细教程
  • VSCODE + EIDE 下 STM32 编程使用部分外设无法通过编译:undefined reference to ‘xxx‘
  • 基于 Transformer RoBERTa的情感分类任务实践总结之五——剪枝
  • 山东大学项目实训-创新实训-法律文书专家系统-项目报告(八)
  • vue中的h渲染函数
  • AI医生24小时在线:你的健康新‘算法监护人
  • 《江西南昌棒垒球》一级运动员 vs 二级运动员·棒球1号位
  • 【C/C++】内核开发之进程调度大纲
  • 2.4k star 开源项目,Wingman AI + 知识图谱,如何帮你搭建‘私人大脑’?学术/项目必备,让笔记真正活起来!
  • Softhub软件下载站实战开发(三):平台管理模块实战
  • 二.TvSettings从Android.bp解析成build.gradle
  • 【Bug】--docker的wsl版本问题
  • Java项目中使用到的技术——《异步调用》
  • K8s集群平台
  • 快手可灵 Q1 营收1.5亿,AI商业化分析:C端订阅+B端API双轮驱动​
  • Appium + .NET 测试全流程
  • 1.MySQL三层结构
  • 深度学习打卡1
  • DependencyMatcher + ML Reranking 策略设计实践
  • 软件工程瀑布模型学习指南
  • Lean 定理证明器工具链管理器 elan工作原理介绍
  • Python训练营---DAY54
  • 综述|探究深度学习在园艺研究中的应用
  • 【CUDA GPU 支持安装全攻略】PyTorch 深度学习开发者指南
  • 3_STM32开发板使用(STM32F103ZET6)
  • Python OpenCV 4.10 库详解
  • SQL 增删改查 —— 笔记篇
  • Day.32
  • langchain从入门到精通(九)——ChatGPT/Playground手动模拟记忆功能