朱派金


私信TA

用户名:zhupaijin

访问量:5414

签 名:

等  级
排  名 1120
经  验 3190
参赛次数 6
文章发表 21
年  龄 21
在职情况 学生
学  校 四川轻化工大学
专  业

  自我简介:

解题思路:

注意事项:

参考代码:

#随便输入一个数
num=int(input())
# 从2开始逐个判断num以内的数,因为任何完数的因数都包含1,所以没有必要增加程序计算量再判断一次1
for i in range(2,num+1):
   list = [1]
   sum = 1
   # 缩短程序计算量,计数到i的一半为止,因为左右两边的因数相乘等于完数
   # pow(x,y)函数,表示计算x的y次方
   C=int(pow(i,0.5))
   for j in range(2,C+1):
       if i%j==0:
           #追加到列表list
           list.append(j)
           list.append(int(i/j))
           sum+=j+i/j
   if sum==i:
       # 给列表数据排序,方便后续以升序输出
       list.sort()
       print(i,'its factors are ',end='')
       for j in range(len(list)):
           print(list[j],end=' ')
       print()



 

0.0分

11 人评分

  评论区

第一个end=' ',引号里面输入一个空格才对
2023-04-02 22:04:41
  • «
  • 1
  • »