Länge einer Sumachsequenz [geschlossen]


11

Eine Sumachsequenz beginnt mit zwei ganzen Zahlen: t 1 und t 2 .

Der nächste Term, t 3 , = t 1 - t 2

Allgemeiner ist t n = t n-2 - t n-1

Die Sequenz endet, wenn t n <0 ist.

Ihre Herausforderung: Schreiben Sie ein Programm oder eine Funktion, die die Länge einer Sumachsequenz druckt, beginnend mit t 1 und t 2 .

  • t 1 und t 2 sind ganze Zahlen im Bereich Ihrer Sprache.
  • Es gelten Standardlücken.

Testfälle

t1  t2       sumac_len(t1,t2)

120  71      5
101  42      3
500  499     4
387  1       3

Bonus Street Cred:

3    -128    1
-314 73      2

Dies ist Code-Golf, also gewinnt die kürzeste Antwort in Bytes.


Eng verwandt , wenn nicht ein Duplikat
Mr. Xcoder

2
Dies scheint eine gute Herausforderung zu sein, ist aber etwas unklar. Sollen wir t1und t2als Input nehmen? Und was ist iin den Testfällen?
Caird Coinheringaahing

2
Ist garantiert, dass t1 und t2> = 0 sind?
user202729

6
@ Blacksilver Huh? Was genau ist dieser Bonus? Bonus werden in der Regel abgeraten sowieso
Luis Mendo

6
Müssen wir damit umgehen t_1 = t_2 = 0? Bedeutet "Bonus Street Cred", dass wir nicht damit umgehen müssen t_1 < 0oder t_2 < 0?
xnor

Antworten:


8

Schale , 8 Bytes

→V<¡oG-↔

Nimmt die Eingabe als 2-Element-Liste auf. Probieren Sie es online aus!

Erläuterung

→V<¡oG-↔  Implicit input, say p=[101,42]
   ¡      Iterate on p:
       ↔    Reverse: [42,101]
    oG-     Cumulative reduce by subtraction: [42,59]
          Result is infinite list [[101,42],[42,59],[59,-17],[-17,76],[76,-93]...
 V<       Find the first index where adjacent pairs are lexicographically increasing.
          In our example [42,59] < [59,-17], so this gives 2.
→         Increment: 3

8

Haskell , 22 Bytes

a#b|b<0=1|c<-a-b=1+b#c

Probieren Sie es online aus!

Ich wünschte wirklich, es gäbe eine Möglichkeit, eine Übereinstimmung für eine negative Zahl zu finden ...

Erläuterung

a#b|b<0=1|c<-a-b=1+b#c

a#b                     -- define a function (#) that takes two arguments a and b
   |b<0                 -- if b is negative...
       =1               -- return 1
         |              -- otherwise...
          c<-a-b        -- assign a-b to c...
                =  b#c  -- and return the result of (#) applied to b and c...
                 1+     -- incremented by 1

Ich denke, die Erklärung ist einmal weniger klar als der Code selbst. : P
Post Rock Garf Hunter

@ WheatWizard Das liegt höchstwahrscheinlich daran, dass ich an Erklärungen lutsche. : P
totalhuman

3

Schale , 12 11 Bytes

V<0t¡ȯF-↑2↔

Probieren Sie es online aus!

Nimmt den Bonus Street Credit für alles, was es wert ist.

Erläuterung

    ¡ȯ       Repeatedly apply the function to the right to the list of all
             previous values and collect the results in an infinite list.
          ↔  Reverse the list of previous results.
        ↑2   Take the first two values (last two results).
      F-     Compute their difference (using a fold).
   t         Discard the first element.
V<0          Find the first index of a negative value.


2

MATL , 13 Bytes

`yy-y0<~]N2-&

Dies behandelt negative Eingaben (die letzten beiden Testfälle).

Probieren Sie es online aus! Oder überprüfen Sie alle Testfälle .

Erläuterung

`        % Do...while
  yy     %   Duplicate top two elements. Implicit inputs first time
  -      %   Subtract
  y      %   Duplicate from below: push previous term
  0<~    %   Is it 0 or greater? This is the loop condition
]        % End. Proceed with next iteration if top of the stack is true
N        % Push number of elements in stack
2-       % Subtract 2
&        % Specify that the next function, namely implicit display, should
         % only display the top of the stack

2

Brain-Flak , 142 90 Bytes

((()){{}<(({}({}))[({}[{}])({})])([(({})<(())>)](<>)){({}())<>}{}{((<{}>))<>{}}{}<>{}>}<>)

Probieren Sie es online aus!

Nicht sehr kurz. Nimmt die Eingabe rückwärts auf.

Erläuterung

(
 (())   #Push 1
 {      #Until 0
  {}    #Pop (+1 to counter)
  <(({}({}))[({}[{}])({})])  #tn = tn-1 - tn-2
  ([(({})<(())>)](<>)){({}())<>}{}{((<{}>))<>{}}{}<>{}>  #Greater than 0?
 }      #End loop
 <>     #Get rid of everything
)       #Push result

2

05AB1E , 11 Bytes

[DŠ-D0‹#]NÌ

Probieren Sie es online aus!

Erläuterung

Nimmt Eingabe als t2, t1

[             # start a loop
 DŠ           # duplicate top of stack and move it down 2 positions
   -          # subtract the top 2 values
    D0‹#      # if a copy of the top value is negative, break loop
        ]     # end loop
         NÌ   # push iteration index+2


1

J , 22 Bytes

[:#({:,-/)^:(0<{:)^:a:

Wie es funktioniert:

                  ^:a: - Repeat until the result stops changing, store the results in a list
          ^:(0<{:)     - repeat if the second term is positive
   ({:,-/)             - makes a tuple (second, first minus second)
[:#                    - number of elements in the list ([: caps the fork)

Probieren Sie es online aus!




0

JavaScript (ES6), 24 Byte

Gibt true anstelle von 1 zurück .

f=(a,b)=>b<0||1+f(b,a-b)

Testfälle


1
@totallyhuman Dann brauchst du f(b)(a-b)also keine Ersparnis.
Herr Xcoder

Was wäre wenn a<0? (Noch 1)
user202729

Update: Sie müssen keine negativen Eingaben mehr unterstützen, aber es ist cool, wenn Sie dies tun.
SIGSTACKFAULT

0

Pyth , 11 Bytes

Dies ist eine rekursive Funktion, die zwei Argumente akzeptiert, Gund H. Der Link wurde leicht modifiziert, um die Funktion für den angegebenen Eingang tatsächlich aufzurufen.

M|<H0hgH-GH

Testsuite.


0

APL (Dyalog) , 23 Bytes

2∘{0>-/⍵:⍺⋄(⍺+1)∇-⍨\⌽⍵}

Probieren Sie es online aus!

Wie?

2∘ - mit einem anfänglichen Akkumulator von 2,

-/⍵ - wenn die nächste Amtszeit

0> - liegt unter 0,

- Akku zurückgeben. Andernfalls,

(⍺+1) - Akku erhöhen

- und mit zurückgreifen

-⍨\⌽⍵ - Die letzten beiden Elemente wurden umgekehrt und differenziert.

      {⍵} 8 2
8 2
      {⌽⍵} 8 2
2 8
      {-⍨\⌽⍵} 8 2
2 6


0

Gleichstrom , 24 Bytes

?[dsb-1rlbrd0<a]dsaxz1-p

Probieren Sie es online aus!

Erläuterung

?                         # read input                | 71 120
 [dsb-1rlbrd0<a]          # push string               | [string] 71 120
                dsa       # copy top to register a    | [string] 71 120
                   x      # execute the string        | -5 27 1 1 1 1
                    z     # push length of stack      | 6 -5 27 1 1 1 1
                     1-   # decrement top by 1        | 5 -5 27 1 1 1 1
                       p  # print top

 # string in register a:

  dsb                     # copy top to register b    | 71 120
     -                    # subtract                  | 49
      1                   # push 1                    | 1 49
       r                  # swap top two elements     | 49 1
        lb                # load register b           | 71 49 1
          r               # swap top two elements     | 49 71 1
           d0<a           # if top < 0 execute register a

0

Z80-Baugruppe, 10 Byte

Diese Version versucht, die "Street Cred" -Version der Aufgabe auszuführen. Für den vorgeschlagenen Testfall mit t1 = -314, t2 = 73 erzeugt dieses Programm jedoch die Antwort "0", was offen gesagt etwas sinnvoller ist als "2".

SumacLen:
        xor a           ; HL = t[1], DE = t[2], A is the counter
Loop:   bit 7,h
        ret nz          ; stop if HL is negative
        inc a
        sbc hl,de       ; HL = t[3], DE = t[2]
        ex de,hl        ; HL = t[2], DE = t[3]
        jr Loop

Das mit Sjasmplus Assembler geschriebene Testprogramm für ZX Spectrum 48K kann hier heruntergeladen werden . Ein kompilierter Schnappschuss ist ebenfalls verfügbar .


Vermutlich verwendet die Nicht-Bonus-Version Loop: ret cstattdessen?
Neil

Ja, das Überprüfen des Vorzeichenbits von H wäre nicht mehr erforderlich. "Bit 7, h" kann entfernt und "ret nz" durch "ret c" ersetzt werden, wobei sich "inc a" direkt davor bewegt. Insgesamt 8 Bytes.
Introspec

Ja; Das 2Ergebnis ist wirklich nur eine Sache mit meinem Programm.
SIGSTACKFAULT

Meinen Sie, dass dies 0eine akzeptable Antwort für diesen Testfall ist? Oder meinst du, es wäre besser, mein Programm für die Ausgabe zu ändern 2?
Introspec



0

Perl 6 ,24 19 Bytes

-5 Bytes dank Brad Gilbert b2gills.

{+(|@_,*-*...^0>*)}

Probieren Sie es online aus!

Erläuterung : Das Ganze in Klammern ist genau die betreffende Sequenz ( |@_sind die ersten beiden Terme (= die beiden Parameter)), *-*eine Funktion, die zwei Argumente akzeptiert und deren Differenz zurückgibt, und * <0die Stoppbedingung (Term kleiner als 0). Wir lassen den letzten Begriff mit ^nach dem ...) weg . Wir erzwingen dann den numerischen Kontext durch den +Operator, der die Länge der Sequenz ergibt.


{+(|@_,*-*...^0>*)}
Brad Gilbert b2gills

@ BradGilbertb2gills: Danke. Ich hatte eine große Pause mit dem Golfen, also bin ich ein bisschen verrostet. Was ich jedoch nicht verstehe, ist, warum Sie das Leerzeichen in * <0*, but why you don't need it in 0> * `...
Ramillies

Der Platz wird benötigt, damit er nicht verwechselt wird mit%h<a>
Brad Gilbert b2gills
Durch die Nutzung unserer Website bestätigen Sie, dass Sie unsere Cookie-Richtlinie und Datenschutzrichtlinie gelesen und verstanden haben.
Licensed under cc by-sa 3.0 with attribution required.