Выведите упрощенную последовательность Гудштейна

22

Число находится в упрощенной форме Гудштейна-b, если оно написано как

b + b + ... + b + c,   0 < c ≤ b

Упрощенная последовательность чисел Гудштейна начинается с записи числа в упрощенной форме Гудштейна с базой 1, затем заменяет все 1 на 2 и вычитает 1. Перепишите результат в упрощенной форме Гудштейна с базой 2, затем замените все 2 на 3 и вычтите 1 и т.д., пока не достигнете 0.

Ваша программа должна взять положительный целочисленный ввод и вывести / распечатать последовательность Goodstein и завершиться. Ваша программа должна обрабатывать числа меньше 100, хотя она может не завершиться в разумные сроки.

Например, если ввести 3 в качестве входных данных, ваша программа должна вывести (правая часть просто пояснение)

1 + 1 + 1                | 3 = 1 + 1 + 1
2 + 2 + 1                | Change 1's to 2's, then subtract 1. (2 + 2 + 2 - 1 = 2 + 2 + 1)
3 + 3                    | 3 + 3 + 1 - 1 = 3 + 3
4 + 3                    | 4 + 4 - 1 = 4 + 3
5 + 2                    | 5 + 3 - 1 = 5 + 2
6 + 1                    | 6 + 2 - 1 = 6 + 1
7                        | 7 + 1 - 1 = 7
7                        | 8 - 1 = 7
6                        | Numbers are now lower than the base, so just keep subtracting 1.
5                        |
4                        |
3                        |
2                        |
1                        |
0                        | End

Интервал не имеет значения.


Критерий победы:

Это . Самый короткий код выигрывает.

Просто Красивое Искусство
источник
1
Обязательно ли включать последние 0?
KSab
5
@KSab Хм .... нет, наверное нет.
Просто Красивое Искусство

Ответы:

2

05AB1E , 19 байтов

Å1[D'+ý,N>D>:`Ž<)0K

Также может быть переставлен как >Å1[ND>:`Ž<)0KD'+ý,

Попробуйте онлайн!

объяснение

Å1                    # push a list of 1's the length of the input
  [                   # start a loop
   D                  # duplicate the current list
    '+ý,              # join on "+" and print
        N>D>:         # replace <current_iteration>+1 with <current_iteration>+2
             `        # flatten the list to the stack
              Ž       # break loop if the stack is empty
               <      # decrement the top number
                )     # wrap the stack in a list
                 0K   # remove zeroes
Emigna
источник
10

Python 2, 77 74 байта

-3 байта благодаря Линн

n=input();b=1
while n:print"+".join(n/b*[`b`]+[`n%b`][:n%b]);n+=n/b-1;b+=1

Попробуйте онлайн!

Легко работает до n = 100 (хотя вывод слишком длинный, чтобы полностью показать tio).

KSab
источник
«Интервал не имеет значения», так что ты в порядке.
Просто Красивое Искусство
Сохраните байт, прочитав входные данные из STDIN:n=input() b=1 while n:…
Линн
1
И еще два с n+=n/b-1;b+=1. 74 байта
Линн
1
@SimplyBeautifulArt исправлено
KSab
1
@SimplyBeautifulArt, очевидно, это связано с циклом while, вы не можете поставить whileследующий a ;. Я предполагаю, что это потому, что если строка начинается с whileкаждого следующего оператора (разделенного точками с запятой), то рассматривается в рамках диапазона while, и поведение будет неоднозначным или, по крайней мере, несколько непрозрачным
KSab
1

Python 3, 155 байт

n=int(input());l=[1]*(n+1);i=0
while l:
    l=[t+1 if t==i else t for t in l];l[-1]-=1;l=l[:-1] if l[-1]==0 else l;print("+".join(list(map(str,l))));i+=1

Это может быть переформатировано в

n = int(input())
l = [0]*(n+1)
i = 0
while l:
    l = [t+1 if t==i else t for t in l]
    if l[-1] == 0:
        l = l[:-1]
    print("+".join(list(map(str,l))))
    i += 1
RGS
источник
Вы пропускаете первую строку 1+1+...и отмечаете, что ваша программа должна обрабатывать любые положительные целочисленные значения.
Просто Красивое Искусство
1
Да, пожалуйста. Кроме того, MathJax не работает на этом сайте: P
Simply Beautiful Art
1
Для меня, кажется, вы поставили пробел в своей версии для гольфа вместо +.
Просто Красивое Искусство
1
106 байт
овс
1
@RGS -~xимеет то же значение, что и x+1, но вам не нужно заключать его в скобки, так как унарный -(отрицание) и унарный ~(побитовое отрицание) имеют более высокий приоритет, чем *. В вашем случае [1]*-~nравно [1]*(n+1).
овс
1

Javascript ES6, 121 символ

for(q=1,s=Array(+prompt()).fill(1).join`+`;s!=0;s=s.split(q).join(++q).replace(/\d+$/,x=>x-1).replace(/\+0$/,''))alert(s)

alert=s=>document.write(s+'\n')
document.write("<pre>")

for(q=1,s=Array(+prompt()).fill(1).join`+`;s!=0;s=s.split(q).join(++q).replace(/\d+$/,x=>x-1).replace(/\+0$/,''))alert(s)

Qwertiy
источник