Kata中的题:求小于10的自然数中被3,5整除的数之和

本文介绍了一种算法,用于计算指定范围内所有3或5的倍数的总和。提供了三种不同的实现方法,包括使用while循环、生成器表达式以及数学公式计算。

如果我们把所有小于10的自然数都列出来,它们是3或5的倍数,我们得到3 5 6和9。这些倍数的和是23 即 3+5+6+9=23。
完成这个解决方案,使它返回所传递的数字的3或5的所有倍数的数字的总和。

1.第一种

def solution(number):
    a =1;sum=0
    while a <number :
        if a % 3 == 0 or a % 5 == 0:
            sum +=a
            a += 1
        else:
            a += 1
    return(sum)
print(solution(10))
#(输出)23

2.第二种

def solution(number):
    return(x for x in range(number) if x % 3==0 or x % 5==0)
    #即 返还值x,x值为 :当x在(0,number)中取数,x被3整除余数为0或x被5整除余数为零的数 ,就被返回为x的值。
a = solution(10)
b1=0
for i in a:
    b1 +=i   #print
print(b1)
#(输出)23
----------------------------------------------------------------------------
可能会有以下的疑惑:
def solution(number):
    return(x for x in range(number) if x % 3==0 or x % 5==0)
print(solution(10))
#(输出)<generator object solution.<locals>.<genexpr> at 0x000001DD5CBA20F8>
这种情况并不是报错 而是生成器序列
想要输出值则:
a = solution(10)
# print(next(a))	#(输出)	0
# print(next(a))	#(输出)	3
#……(一个一个的出现)

for i in a:
    print(i)
#(输出)	0
		3
		5
		6
		9
然后在计算和即可

或者以列表方式打印出结果:
print(list(solution(10)))

3.第三种

modN = lambda m, n: (n-1) // m
sumN = lambda m, n: m * n*(n+1)/2
comF = lambda m, n: sumN(m, modN(m, n))

def solution(n):
    return comF(3, n) + comF(5, n) - comF(15, n)
print(solution(10))
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值