• 当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 新婚迎宾海报祝福语简短