我的程序能够判断完全数,但是当遇到很大的数的时候程序运行时间就会很长,求优化的程序
2条回答 默认 最新
- 快乐鹦鹉 2022-10-18 20:03关注
首先是有错误,第8行循环i不能从0开始,否则num%i就出问题了
优化如下:int k = sqrt(num); for(int i=1;i<=k;i++) { if(num%i==0) { res += i; if(i*i != num) res += num/i; } }
只需要num开根号次数,大大减小了
本回答被题主选为最佳回答 , 对您是否有帮助呢?解决 无用评论 打赏 举报 编辑记录
悬赏问题
- ¥15 PointNet++的onnx模型只能使用一次
- ¥20 西南科技大学数字信号处理
- ¥15 有两个非常“自以为是”烦人的问题急期待大家解决!
- ¥30 STM32 INMP441无法读取数据
- ¥15 R语言绘制密度图,一个密度曲线内fill不同颜色如何实现
- ¥100 求汇川机器人IRCB300控制器和示教器同版本升级固件文件升级包
- ¥15 用visualstudio2022创建vue项目后无法启动
- ¥15 x趋于0时tanx-sinx极限可以拆开算吗
- ¥500 把面具戴到人脸上,请大家贡献智慧,别用大模型回答,大模型的答案没啥用
- ¥15 任意一个散点图自己下载其js脚本文件并做成独立的案例页面,不要作在线的,要离线状态。