summaryrefslogtreecommitdiff
path: root/euler45.myr
blob: 3bf53fc85b9697e86eacd49a8496ec8b7b55f1f6 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
use std

const main = {
	for var n: uint64 = 144; true; n++
		var hn = n * (n * 2 - 1)
		/* find pentagonal pn = n(3n-1)/2 */
		/* n' < 2/sqrt(3)*n */
		var i: uint64 = n * 148 / 128
		var pn = i * (i * 3 - 1) / 2
		while pn > hn
			i--
			pn = i * (i * 3 - 1) / 2
		;;
		if (pn != hn)
			continue
		;;
		/* find triangle tn = n(n+1)/2, n'<2n */
		i = n*2
		var tn = i * (i + 1) / 2
		while tn > hn
			i--
			tn = i * (i + 1) / 2
		;;
		if (tn != hn)
			continue
		;;
		std.put("n = {}, h[n] = {}\n", n, hn)
		break
	;;
}