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
;;
}
|