Files
zern/examples/puzzles/euler_12.zr
2025-12-23 17:08:42 +01:00

21 lines
405 B
Plaintext

func num_divisors[n: i64] : i64
let end: i64 = math.isqrt(n)
let out: i64 = 0
for i in 1..end+1
if n % i == 0
out = out + 2
if end * end == n
out = out - 1
return out
func main[] : i64
let n: i64 = 0
let i: i64 = 1
while true
n = n + i
if num_divisors(n) > 500
io.println_i64(n)
break
i = i + 1