• 当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 年轻20岁祝福语简短
    11 朋友结婚祝福语信息简短
    12 女孩婚礼贺卡祝福语简短
    13 30段点歌简短祝福语
    14 虎年春节祝福语图文简短
    15 写给后妈祝福语大全简短
    16 简短回复生日祝福语
    17 校长送毕业祝福语简短
    18 毕业立体贺卡祝福语简短