Python算法100例-3.4 完数

本文详细描述了如何使用Python编程解决求某一范围内完数的问题,通过分析定义、设计算法,利用两层循环遍历并判断因子,同时强调了变量初始化和效率提升的重要性。最后给出了优化后的代码,提高了程序运行效率。

完整源代码项目地址,关注博主私信'源代码'后可获取

1.问题描述

求某一范围内完数的个数。

如果一个数等于它的因子之和,则称该数为“完数”(或“完全数”)。例如,6的因子为1、2、3,而6=1+2+3,因此6是“完数”。

2.问题分析

根据完数的定义,解决本题的关键是计算出所选取整数i(i的取值范围不固定)的因子(因子就是所有可以整除这个数的数),然后将各因子累加到变量s(记录所有因子之和),若s等于i,则可确认i为完数,反之则不是完数。

3.算法设计

对于这类求某一范围(本题范围不固定,在编程过程中采用键盘输入的方式)内满足条件的数的问题,一般采用遍历的方式,即一个一个地去判断给定范围内的数值是否满足条件,这一过程可利用循环来实现。

本题的关键是求出选取数值i的因子,即从1到i-1范围内能整除i的数。看某一个数j是不是i的因子,可利用语句“if i%j==0”进行判断,求某一个数的所有因子,需要在1到i-1范围内进行遍历,同样采用循环实现。因此,本题从整体上看可利用两层循环来实现。外层循环控制该数的范围为2~n;内层循环j控制除数的范围为1~i,通过判断i对j取余是否等于0,找到该数的各个因子。程序段如下:

i = 2                                                   # 变量 i 控制选定数的范围
while i <= n:
     ...
     for j in range(i):
         ...

     if s <
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

飘逸高铁侠

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值