OFFSET
0,3
COMMENTS
This sequence is similar to the Recamán sequence A005132 except that here the number chosen to step to, if a(n-1) - n is >= 0, is determined by which of the two possible numbers, a(n-1) - n or a(n-1) + n, has appeared the fewest times. If the number of times these numbers have appeared is the same then a(n) = a(n-1) - n. If a(n-1) - n is less than zero then a(n) = a(n-1) + n.
The first term to differ from A005132 is a(39) = 0. See the examples below. In the first 10^8 terms the largest value is a(99928118) = 842174195, while the smallest number not to have appeared is 366. It is likely all numbers eventually appear although this is unknown.
See the companion sequence A350579 for the first number to appear n times.
LINKS
EXAMPLE
a(3) = 6 as a(2) = 3 giving the two possible numbers for the next step as 0 or 6. But 0 has already appeared once while 6 has not yet appeared, so 6 is chosen.
a(39) = 0 as a(38) = 39 giving the two possible numbers for the next step as 0 or 78. Both 0 and 78 have already appeared once thus the smaller is chosen. This is the first term to differ from A005132.
a(447) = 934 as a(446) = 487 giving the two possible numbers for the next step as 40 or 934. 40 has already appeared twice while 934 has appeared once, so the later is chosen. This is the first time both possible numbers have already appeared and the larger is chosen.
a(2462) = 551 as a(2461) = 3013 giving the two possible numbers for the next step as 551 or 5475. 551 has already appeared once while 5475 has appeared twice, so the former is chosen. This is the first time both possible numbers have already appeared and the smaller is chosen.
MATHEMATICA
a[0]=0; a[n_]:=a[n]=If[a[n-1]-n>=0&&Count[Array[a, n-1, 0], a[n-1]-n]<=Count[Array[a, n-1, 0], a[n-1]+n], a[n-1]-n, a[n-1]+n]; Array[a, 74, 0] (* Giorgos Kalogeropoulos, Jan 07 2022 *)
PROG
(Python)
from itertools import count, islice
from collections import Counter
def A350578_gen(): # generator of terms
yield 0
b, bcounter = 0, Counter({0})
for n in count(1):
b += -n if b-n >= 0 and bcounter[b-n] <= bcounter[b+n] else n
bcounter[b] += 1
yield b
CROSSREFS
KEYWORD
nonn
AUTHOR
Scott R. Shannon, Jan 07 2022
STATUS
approved