题解 | #字符串通配符# 递归的完全解

字符串通配符

https://www.nowcoder.com/practice/43072d50a6eb44d2a6c816a283b02036

import sys
import re

A = input().lower()
B = input().lower()
mem = {}

def match(rule_index: int, string_index: int):

    if (rule_index,string_index) in mem: 
        return mem[(rule_index,string_index)]

    rule,string = A[rule_index:], B[string_index:]

    if not rule and not string:
        mem[(rule_index,string_index)] = True
        return True

    if not rule and string:
        mem[(rule_index,string_index)] = False
        return False

    if rule and not string:
        if set(rule) == {'*'}:
            mem[(rule_index,string_index)] = True
            return True
        mem[(rule_index,string_index)] = False
        return False

    
    if rule == '*' and string.isalnum():
        mem[(rule_index,string_index)] = True
        return True
        
    result = False
    if rule[0] == string[0] or (rule[0] == '?' and string[0].isalnum()): 
        result = match(rule_index+1,string_index+1)

    if rule[0] == '*':
        result = match(rule_index+1,string_index) or match(rule_index,string_index+1)
    
    mem[(rule_index,string_index)] = result  
    return result



print(str(match(0,0)).lower())


这道题目最好是用动态规划来做,如果要用递归的话,需要使用一个字典来保存已有的结果来减少计算次数(其实等价于动态规划)

全部评论

相关推荐

05-29 09:02
门头沟学院 Java
点赞 评论 收藏
分享
07-01 17:14
中北大学 Java
兄弟们是真是假
牛客46374834...:我在boss上投java岗从来没成功过
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

更多
牛客网
牛客网在线编程
牛客网题解
牛客企业服务