博客
关于我
2021牛客寒假算法基础集训营3 F.匹配串
阅读量:169 次
发布时间:2019-02-28

本文共 1261 字,大约阅读时间需要 4 分钟。

为了解决这个问题,我们需要判断给定的多个模式串是否存在一个共同的匹配串,使得所有模式串在替换#后的结果完全相同。如果存在这样的匹配串,我们需要判断其数量是否为有限值或无穷值。

方法思路

  • 问题分析:每个模式串包含小写字母和至少一个#,其中#可以被替换为任意长度的任意小写字母字符串。我们需要找到所有模式串在替换#后的结果相同的情况。
  • 关键观察:对于所有模式串,替换后的结果必须具有相同的前缀和后缀。前缀是指模式串开头的连续小写字母部分,后缀是指模式串结尾的连续小写字母部分。
  • 算法步骤
    • 对于每个模式串,计算其前缀(从开始到第一个#之前的所有字符)和后缀(从最后一个#之后到末尾的所有字符)。
    • 比较所有模式串的前缀是否相同。
    • 比较所有模式串的后缀是否相同。
    • 如果前缀和后缀都相同,则中间的#部分可以被统一替换,导致无穷多个匹配串,输出-1。否则,输出0。
  • 解决代码

    import sysdef main():    n = int(sys.stdin.readline())    prefix = []    suffix = []        for _ in range(n):        s = sys.stdin.readline().strip()        # 计算前缀        pre = []        for c in s:            if c == '#':                break            pre.append(c)        pre_str = ''.join(pre)        prefix.append(pre_str)        # 计算后缀        i = len(s) - 1        while i >= 0 and s[i] != '#':            i -= 1        suffix_str = s[i+1:]        suffix.append(suffix_str)        # 检查前缀是否都相同    if len(set(prefix)) != 1:        print(0)    else:        # 检查后缀是否都相同        if len(set(suffix)) != 1:            print(0)        else:            print(-1)if __name__ == "__main__":    main()

    代码解释

  • 读取输入:使用sys.stdin.readline读取输入,处理大量数据会更高效。
  • 计算前缀和后缀:对于每个模式串,计算其前缀和后缀。前缀是从开始到第一个#之前的所有字符,后缀是从最后一个#之后到末尾的所有字符。
  • 检查前缀和后缀:将所有模式串的前缀和后缀存储在列表中,检查这些列表是否有相同的值。如果有,则输出-1,表示存在无穷多个匹配串;否则,输出0。
  • 转载地址:http://nhjj.baihongyu.com/

    你可能感兴趣的文章
    nodejs中Express 路由统一设置缓存的小技巧
    查看>>
    Nodejs中的fs模块的使用
    查看>>
    nodejs包管理工具对比:npm、Yarn、cnpm、npx
    查看>>
    NodeJs单元测试之 API性能测试
    查看>>
    nodejs图片转换字节保存
    查看>>
    nodejs字符与字节之间的转换
    查看>>
    NodeJs学习笔记001--npm换源
    查看>>
    NodeJs学习笔记002--npm常用命令详解
    查看>>
    nodejs学习笔记一——nodejs安装
    查看>>
    nodejs封装http请求
    查看>>
    nodejs常用组件
    查看>>
    nodejs开发公众号报错 40164,白名单配置找不到,竟然是这个原因
    查看>>
    Nodejs异步回调的处理方法总结
    查看>>
    NodeJS报错 Fatal error: ENOSPC: System limit for number of file watchers reached, watch ‘...path...‘
    查看>>
    Nodejs教程09:实现一个带接口请求的简单服务器
    查看>>
    nodejs服务端实现post请求
    查看>>
    nodejs框架,原理,组件,核心,跟npm和vue的关系
    查看>>
    Nodejs模块、自定义模块、CommonJs的概念和使用
    查看>>
    nodejs生成多层目录和生成文件的通用方法
    查看>>
    nodejs端口被占用原因及解决方案
    查看>>