Loading [MathJax]/jax/output/HTML-CSS/jax.js

Pentagon numbers

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?


Idea

Naive solution.

Assume j<k, so Pj<Pk, so D=|PkPj|=PkPj=k(3k1)2j(3j1)2=(kj)(3(k+j)1)2.

Let t=kj, 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=k1,....,1


In [1]:
from math import ceil, sqrt
In [2]:
def get_pentagon(n):
    return n * (3*n-1) // 2
In [3]:
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
In [4]:
is_sum_pentagon(22, 70)
Out[4]:
True
In [5]:
is_sum_pentagon(12, 22)
Out[5]:
False
In [6]:
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
In [7]:
solve()
Out[7]:
5482660