我在这里有一个 dict 和一个字符串,其中 dict 包含 char-count 作为键值对。我想检查字符串中的所有字符是否完全包含在字典中。
这意味着字典应该包含字符串的所有字符,它们的计数小于或等于它们在字典中的对应值。
def isValidWord(strng, dct):
"""
Returns True if strng is entirely
composed of letters in the dct.
Otherwise, returns False.
Does not mutate hand or dct.
"""
d={}
for x in strng:
d[x]=d.get(x,0)
for x in d:
if d[x]> dct.get(x,0):
return False
return True
在大多数情况下它似乎工作得很好,但在某些情况下却不行。例如 -
isValidWord('chayote', {'a': 1, 'c': 2, 'u': 2, 't': 2, 'y': 1, 'h': 1, 'z': 1,
'o': 2})
这给出了输出True
,但是正确的输出是False
. 这是因为e
字典中没有。
这里的错误在哪里?以及如何检查一个字典中的所有对是否也存在于另一个字典中,可能具有相等或较低的对应值(键)。