鱼C论坛

 找回密码
 立即注册
查看: 1933|回复: 4

[已解决]求问怎么最快速计算一个数所有的约数

[复制链接]
发表于 2017-3-17 16:14:46 | 显示全部楼层 |阅读模式

马上注册,结交更多好友,享用更多功能^_^

您需要 登录 才可以下载或查看,没有账号?立即注册

x
RT,虽然可以用迭代来算出所有约数,但是效率太慢了,有没有大神教一个快一点的办法
最佳答案
2017-3-23 09:10:33

  1. shu=10000
  2. result=[a for a in range(1,shu+1) if shu%a==0]
  3. print(result)
复制代码
小甲鱼最新课程 -> https://ilovefishc.com
回复

使用道具 举报

发表于 2017-3-23 09:10:33 | 显示全部楼层    本楼为最佳答案   

  1. shu=10000
  2. result=[a for a in range(1,shu+1) if shu%a==0]
  3. print(result)
复制代码
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2017-3-23 11:57:04 | 显示全部楼层

额,我只看得懂C语言....其他的看不懂呀
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2017-3-23 12:13:46 | 显示全部楼层
自由深渊 发表于 2017-3-23 11:57
额,我只看得懂C语言....其他的看不懂呀
  1. #include "stdafx.h"
  2. int main(int argc, char* argv[])
  3. {  
  4. int i,q,sum=0;
  5.     scanf("%d",&q);
  6.     for(i=1;i<=q;i++)//这里你不能取i=0,那样是错的。0能做被除数吗?改为1
  7.     {
  8.   if(q%i==0)
  9.         sum=sum+i;
  10. }
  11.     printf("%d",sum);
  12. return 0;
  13. }
复制代码
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2017-3-26 14:03:50 | 显示全部楼层
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

小黑屋|手机版|Archiver|鱼C工作室 ( 粤ICP备18085999号-1 | 粤公网安备 44051102000585号)

GMT+8, 2025-6-9 07:48

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

快速回复 返回顶部 返回列表