题目内容:
如果一个n位数刚好包含了1至n中所有数字各一次则称它们是全数字(pandigital)的,例如四位数1324就是1至4全数字的。从键盘上输入一组整数,输出其中的全数字,若找不到则输出“not found”。形如:
def pandigital(nums):
…
return lst
if name == “main”:
lst = pandigital(eval(input()))
调用函数根据结果输出
输入格式:
多个数字串,中间用一个逗号隔开
输出格式:
满足条件的数字串,分行输出
输入样例:
1243,322,321,1212,2354
输出样例:
1243
321
时间限制:1800ms内存限制:32000kb
答案(python 2.7)
def pandigital(nums):
b=[]
for i in nums.split(","):
maxnumber=int(max(str(i)))
if len(i)== maxnumber and len(set(i))==maxnumber:
b.append(i)
continue
return b
if __name__ == "__main__":
lst = pandigital(raw_input())
if len(lst)!=0:
for i in lst:
print i
else:
print "not found"
本文介绍了一个用于筛选全数字(pandigital)数目的算法。全数字是指一个n位数恰好包含1至n的所有数字各一次的数目。文章提供了一个Python实现,能够从一组输入数字中筛选出所有符合条件的全数字,并提供了完整的代码示例。
1651

被折叠的 条评论
为什么被折叠?



