Pentagonal numbers are generated by the formula, Pn=n(3n−1)/2. The first ten pentagonal numbers are:
1, 5, 12, 22, 35, 51, 70, 92, 117, 145, ...
It can be seen that P4 + P7 = 22 + 70 = 92 = P8. However, their difference, 70 − 22 = 48, is not pentagonal.
Find the pair of pentagonal numbers, Pj and Pk, for which their sum and difference are pentagonal and D = |Pk − Pj| is minimised; what is the value of D?
Naive solution.
Assume j<k, so Pj<Pk, so D=|Pk−Pj|=Pk−Pj=k(3k−1)2−j(3j−1)2=(k−j)(3(k+j)−1)2.
Let t=k−j, then D=t(3(t+2j)−1)2, it always increases w.r.t t, since j>0.
So for a certain k, we will search through j=k−1,....,1
from math import ceil, sqrt
def get_pentagon(n):
return n * (3*n-1) // 2
def is_sum_pentagon(pj, pk):
n = ceil(sqrt(pj+pk) / sqrt(3/2))
while get_pentagon(n) < pj + pk:
n += 1
return get_pentagon(n) == pj + pk
is_sum_pentagon(22, 70)
is_sum_pentagon(12, 22)
def solve():
pentagon_numbers = set([0, 1])
k = 2
while True:
pk = get_pentagon(k)
pentagon_numbers.add(pk)
for j in range(k-1, 0, -1):
pj = get_pentagon(j)
if (pk-pj) in pentagon_numbers and is_sum_pentagon(pj, pk):
return pk - pj
k += 1
solve()