某Python群的入群题目

为了确保不被通过搜索引擎直接搜索题目搜出来,我重新描述下题目:

给n, 求1~n的每个数的约数和

每个约数出现的个数是 n // i个,

出现x次的约数范围是[n // (i + 1) + 1, n // i]

def my_sum(n):
res = 0
for i in range(1, int(n**0.5) + 1):
res += n // i * i
j = n // i
k = n // (i + 1)
if j != i:
res += (j + k + 1) * (j - k) // 2 * i
return res

答案 357340138978

转载于:https://www.cnblogs.com/cfy42/p/4825663.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值