Wyjście uproszczonej sekwencji Goodsteina


22

Liczba ma uproszczoną bazę Goodsteina, jeśli jest zapisana jako

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

Uproszczona sekwencja liczb Goodsteina zaczyna się od wpisania liczby w uproszczonej formie Goodsteina base-1, a następnie zamienia wszystkie 1 na 2 i odejmuje 1. Przepisz wynik w postaci uproszczonej base-2, a następnie zamień wszystkie 2 na 3 i odejmij 1 itd., dopóki nie osiągniesz 0.

Wasz program ma przyjąć dodatnią liczbę całkowitą wejściową i wyjściową / wydrukować sekwencję Goodsteina i zakończyć. Twój program powinien obsługiwać liczby mniejsze niż 100, chociaż może nie zakończyć się w rozsądnym czasie.

Na przykład, biorąc pod uwagę 3 jako dane wejściowe, twój program powinien wypisać (prawa strona to tylko wyjaśnienie)

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

Odstępy nie mają znaczenia.


Kryterium wygranej:

To jest . Najkrótszy kod wygrywa.


1
Czy wymagane jest podanie ostatniego 0?
KSab

5
@KSab Hm .... nie, chyba nie.
Po prostu piękna sztuka

Odpowiedzi:


2

05AB1E , 19 bajtów

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

Można również zmienić układ jako >Å1[ND>:`Ž<)0KD'+ý,

Wypróbuj online!

Wyjaśnienie

Å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

10

Python 2, 77 74 bajtów

-3 bajty dzięki Lynn

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

Wypróbuj online!

Z łatwością osiąga wartość n = 100 (choć wyjście jest zbyt długie, aby tio w pełni pokazało).


„Odstęp nie ma znaczenia”, więc wszystko jest w porządku.
Po prostu piękna sztuka

Zapisz bajt, czytając dane wejściowe ze STDIN:n=input() b=1 while n:…
Lynn,

1
I jeszcze dwa z n+=n/b-1;b+=1. 74 bajty
Lynn

1
@SimplyBeautifulArt naprawiono
KSab

1
@SimplyBeautifulArt najwyraźniej ma to związek z pętlą while, nie można umieścić whilenastępującego ;. Sądzę, że dzieje się tak, ponieważ jeśli linia jest uruchamiana za pomocą whilekażdej kolejnej instrukcji (oddzielonej średnikami), jest ona rozważana w jej zakresie czasu, a zachowanie byłoby dwuznaczne lub przynajmniej nieco nieprzejrzyste
KSab


2

Mathematica, 123 bajty

(s=1~Table~#;i=1;While[s!={},Print@StringRiffle[ToString/@s,"+"];s=s/.i->i+1;s=Join[Most@s,{Last@s}-1]~DeleteCases~0;i++])&


Wypróbuj online!


1

Python 3, 155 bajtów

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

Można to przeformatować na

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

Tęsknisz za pierwszym wierszem 1+1+...i zauważ, że twój program powinien obsłużyć każdą dodatnią liczbę całkowitą.
Po prostu piękna sztuka

1
Tak proszę. Ponadto MathJax nie działa na tej stronie: P
Po prostu piękna sztuka

1
Dla mnie wygląda na to, że umieściłeś miejsce w swojej wersji golfowej zamiast +.
Po prostu piękna sztuka


1
@RGS -~xma taką samą wartość jak x+1, ale nie trzeba jej umieszczać w nawiasach, ponieważ unary -(negacja) i unary ~(negacja bitowa) mają wyższy priorytet niż *. W twoim przypadku [1]*-~njest równa [1]*(n+1).
ovs

1

JavaScript ES6, 121 znaków

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)


Korzystając z naszej strony potwierdzasz, że przeczytałeś(-aś) i rozumiesz nasze zasady używania plików cookie i zasady ochrony prywatności.
Licensed under cc by-sa 3.0 with attribution required.