解题思路:其实思路还是比较简单明确的,主要在于减少循环次数,减少运行时间
参考代码:
N=int(input()) for i in range(6,N+1): #从6开始,减少循环次数 a=1 lis=[1] c=int(pow(i,0.5))+1 for j in range(2,c): if i%j==0: #a=a+j lis.append(j) lis.append(int(i/j)) a=a+j+int(i/j) if a==i: lis.sort() print(a,'its factors are',end=' ') for h in lis: print(h,end=' ') print()
求其因数,理论上只要求得该数的二分之一次方处即可
0.0分
0 人评分
整除问题 (C语言代码)浏览:949 |
C语言程序设计教程(第三版)课后习题5.7 (C语言代码)浏览:674 |
Tom数 (C++代码)浏览:869 |
C语言训练-计算1~N之间所有奇数之和 (C语言代码)浏览:689 |
C语言程序设计教程(第三版)课后习题1.5 (C语言代码)浏览:644 |
Wu-求圆的面积 (C++代码)浏览:1994 |
【计算直线的交点数】 (C语言代码)浏览:1501 |
星期判断机 (C语言代码)浏览:892 |
printf基础练习2 (C语言代码)浏览:547 |
简单的a+b (C语言代码)浏览:572 |