这里是初学者--给定一个字符串,我的代码必须检测它是否是pangram。如果是,则返回True;如果not.It应忽略数字和标点符号,则返回False。
当给出"ABCD45EFGH,IJK,LMNOPQR56STUVW3XYZ“时,它返回none;当给出"This is not a pangram!is not a pangram”时,它返回none。当答案应该为False时,它返回True。
这不是pangram!不是pangram。我没看到的是什么?
import string
def is_pangram(s):
singlechar = set(s)
list = ['a', 'b', 'c', 'd', 'e', 'f', 'g', 'h', 'i', 'j', 'k', 'l', 'm', 'n', 'o', 'p', 'q', 'r', 's', 't', 'u', 'v', 'w', 'x', 'y', 'z']
for index, item in enumerate(singlechar):
if item in list:
list.remove(item)
if list:
return True
break
if not list:
return False
发布于 2021-10-25 21:08:20
您可以继续使用集合及其方法.difference
来确定所有字符的集合中是否有更多的字符,或者没有差异(在此之前,您需要去掉字符串的标点符号(和空格)并使其小写(由字符串的.lower
、.translate
和.maketrans
方法完成):
import string
def is_pangram(s):
input_set = set(s.lower().translate(
str.maketrans('', '', f'{string.punctuation} ')))
check_set = set(string.ascii_lowercase)
return not check_set.difference(input_set)
value1 = 'The quick brown fox jumps over a lazy dog!'
print(is_pangram(value1))
# True
value2 = 'This isn\'t a pangram! is not a pangram'
print(is_pangram(value2))
# False
如果你仍然想用一个列表来做:
def is_pangram(s):
input_set = set(s.lower().translate(
str.maketrans('', '', f'{string.punctuation} ')))
lst = list(string.ascii_lowercase)
for item in input_set:
if item in lst:
lst.remove(item)
if not lst:
return True
return False
发布于 2021-10-25 21:13:58
集合是一种很好的方法,可以用来检查某些东西是属于两个具有交集的集合,还是不属于具有差异的两个集合中的一个。
在您的例子中,如果短语中的字母集与字母a-z之间的交集长度为26,则它是一个pangram。
from string import ascii_lowercase
def is_pangram(s):
return len(set(s.lower()).intersection(ascii_lowercase)) == 26
https://stackoverflow.com/questions/69714586
复制相似问题