因子平方和

题目描述如下:
6 的因子有 1, 2, 3 和 6, 它们的平方和是 1 + 4 + 9 + 36 = 50. 如果 f(N) 代表正整数 N 所有因子的平方和, 那么 f(6) = 50.现在令 F 代表 f 的求和函数, 亦即
F(N) = f(1) + f(2) + .. + f(N), 显然 F 一开始的 6 个值是: 1, 6, 16, 37, 63 和 113.
那么对于任意给定的整数 N (1 <= N <= 10^8), 输出 F(N) 的值.

Version1

def F(n):
    allsum=0
    for x in range(1,n+1):
        buf=[]
        sum=0
        for i in range(1,x+1):
            if x%i==0:
                buf.append(i)
        for j in buf:
            sum+=j*j
        allsum+=sum
    return allsum
print F(N)

初始版本,毫无疑问在N较大时候,超时了。

Version2

分析规律

N = 10
def Lf(n):
    L = []
    for i in range(1,n+1):
        if n % i ==0:
            L.append(i)
    return L
for i in range(1,N+1):
    print(Lf(i))

结果如下:

[1]
[1, 2]
[1, 3]
[1, 2, 4]
[1, 5]
[1, 2, 3, 6]
[1, 7]
[1, 2, 4, 8]
[1, 3, 9]
[1, 2, 5, 10]

统计F(N)每个数出现的次数
N = 10
L1 = list(range(1,N+1))
L2 = [N/i for i in L1]
print (L1)
print (L2)

结果如下:

[1, 2, 3, 4, 5, 6, 7, 8, 9, 10]
[10, 5, 3, 2, 2, 1, 1, 1, 1, 1]

发现有1有10个,2有5个,3有3个,4有2个,5有2 个。。。
即F(N)==1^2*(N//1)+2^2*(N//2)+…+N^2*(N//N)

def F(N):
    result = 0;
    for x in range( 1, N  + 1):
            result += ((N/x) * (x**2))
    return result
print F(N)  

结果正确,但是依然会超时。

Version3

[1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 15, 16, 17, 18, 19, 20]
[20, 10, 6, 5, 4, 3, 2, 2, 2, 2, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1]

列了一下这个才注意到后半部分的个数全是1,所以可以前半部分和后半部分分开计算:
后半部分可以利用平方和公式进行计算。

def F(N):
    result = 0;
    for x in range( 1, N /2 + 1):
            result += ((N/x) * (x**2))
    result += (N*(N+1)*(2*N+1)-(N/2)*(N/2+1) * ((N/2)*2+1))/6
    return result
print F(N)
  • 2
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值