解题思路:其实思路还是比较简单明确的,主要在于减少循环次数,减少运行时间
参考代码:
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语言训练-角谷猜想 (C++代码)(3N+1问题)浏览:1837 |
C语言程序设计教程(第三版)课后习题9.6 (C语言代码)浏览:282 |
printf基础练习2 (C语言代码)浏览:952 |
C语言程序设计教程(第三版)课后习题5.7 (Java代码)浏览:905 |
蛇行矩阵 (C语言代码)浏览:599 |
printf基础练习2 (C语言代码)浏览:648 |
回文数字 (C语言代码)浏览:2532 |
矩阵加法 (C语言代码)浏览:1759 |
母牛的故事 (C语言代码)浏览:1007 |
C语言程序设计教程(第三版)课后习题12.2 (C语言代码)浏览:833 |