• 当t中的任何字符不在s中时,检查前两个字符(前两个ASCII值)是否在s中。例如,如果'f'在t中但不在s中,那么'd'和'e'可以从s中生成'f'。

  • 因此,如果输入类似于s="pghn"t="pin",那么输出将为True,因为我们可以从'g'和'h'生成'i'以生成“pin”。

    让我们看看以下实现以获得更好的理解-

    示例

    from collections import defaultdict
    def solve(s, t):
       freq = defaultdict(lambda:0)
       for i in range(0, len(s)):
          freq[s[i]] += 1
       for i in range(0, len(t)):
          if freq[t[i]]:
             freq[t[i]] -= 1
          elif (freq[chr(ord(t[i]) - 1)] and freq[chr(ord(t[i]) - 2)]):
             freq[chr(ord(t[i]) - 1)] -= 1
             freq[chr(ord(t[i]) - 2)] -= 1
          else:
             return False
       return True
    s = "pghn"
    t = "pin"
    print(solve(s, t))

    输入

    "pghn", "pin"

    输出结果

    True

    热门推荐

    1 新春进门祝福语大全简短
    2 新郎表白成语祝福语简短
    3 参加儿子大学祝福语简短
    4 订婚新发言简短祝福语
    5 日语送考祝福语简短
    6 夸赞老师祝福语搞笑简短
    7 老师对学校祝福语简短
    8 祝福语怎么写大全简短
    9 对疫情的简短祝福语
    10 小红书平安祝福语简短
    11 生日祝福语大全女孩简短
    12 收生日红包祝福语 简短
    13 领证幽默祝福语简短
    14 法考面试祝福语简短
    15 老哥出门祝福语简短语
    16 送灯祝福语简短独特
    17 幼儿狗年祝福语大全简短
    18 好听的元旦简短祝福语