2017-11-18 16:45:28 +01:00
|
|
|
#!/usr/bin/env python
|
|
|
|
# -*- coding: utf-8 -*-
|
|
|
|
|
|
|
|
"""
|
|
|
|
Napisz funkcję sum_div35(n), która zwraca sumę wszystkich liczb podzielnych
|
|
|
|
przez 3 lub 5 mniejszych niż n.
|
|
|
|
"""
|
|
|
|
|
|
|
|
def sum_div35(n):
|
2017-11-29 14:43:45 +01:00
|
|
|
suma = 0
|
|
|
|
for i in range(n-1):
|
|
|
|
if (i+1) % 3 == 0 or (i+1) % 5 == 0:
|
|
|
|
suma+=i+1
|
|
|
|
return suma
|
2017-11-18 16:45:28 +01:00
|
|
|
|
|
|
|
def tests(f):
|
|
|
|
inputs = [[10], [100], [3845]]
|
|
|
|
outputs = [23, 2318, 3446403]
|
|
|
|
|
|
|
|
for input, output in zip(inputs, outputs):
|
|
|
|
if f(*input) != output:
|
|
|
|
return "ERROR: {}!={}".format(f(*input), output)
|
|
|
|
break
|
|
|
|
return "TESTS PASSED"
|
|
|
|
|
|
|
|
if __name__ == "__main__":
|
|
|
|
print(tests(sum_div35))
|
|
|
|
|