python 寻找输入数字中的全数字

寻找输入数字中的全数字(pandigital)。(4分)
题目内容:

如果一个n位数刚好包含了1至n中所有数字各一次则称它们是全数字(pandigital)的,例如四位数1324就是1至4全数字的。从键盘上输入一组整数,输出其中的全数字,若找不到则输出“not found”。形如:

def pandigital(nums):

return lst

def pandigital(nums): 
      ......
      return lst
if __name__ == "__main__":
      lst = pandigital(eval(input()))

if name == “main”:
lst = pandigital(eval(input()))
调用函数根据结果输出

输入格式:

多个数字串,中间用一个逗号隔开

输出格式:

满足条件的数字串,分行输出

输入样例:

1243,322,321,1212,2354

输出样例:

1243

321

本题主要考察的是python语言中list这个数据结构的使用,首先读入数据,用eval转化成数字,用两个list分别存答案与输入数据,其中答案为对应n为数的n个数字,用一个for逐一添加到list中。之后再对这个列表遍历,如果在输入数字中发现对应这一数字,则将其加入到第二个list中,最后比较两个list的len,若相等,则数字符合题意。

def pandigital(nums):
    flag = False
    for num in nums:
        num = str(num)
        all_number_list=[]
        all_number_in_num_list=[]

        for i in range(1, len(num) + 1):
            all_number_list.append(str(i))
        for j in all_number_list:
            if j in num:
                all_number_in_num_list.append(j)
            
        
        if len(all_number_list) == len(all_number_in_num_list):
            print(num)
            flag = True
    if flag == 0:
        print('not found')
if __name__ == "__main__":
    lst = pandigital(eval(input()))

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值