So wird die Kolakoski-Sequenz (OEIS A000002 ) definiert:
Die Kolakoski-Folge ist eine Folge, die
1und enthält2, und dasndritte Element der Folge ist die Länge derndritten Gruppe gleicher Elemente (Lauf) in der Folge selbst. Die ersten 20 Terme der Sequenz und die jeweiligen Längen sind:1 2 2 1 1 2 1 2 2 1 2 2 1 1 2 1 1 2 2 1 - --- --- - - --- - --- --- - --- --- - 1 2 2 1 1 2 1 2 2 1 2 2 1Im Wesentlichen ist die Länge der Gruppen gleicher Elemente der Kolakoski-Sequenz die Kolakoski-Sequenz selbst.
So weit, so gut, aber warum sollten wir uns auf 1und beschränken 2? Wir werden nicht! Bei zwei Eingaben, einer Reihe positiver Ganzzahlen Aund einer ganzen Zahl N, werden die ersten NTerme der Kolakoski-ähnlichen Sequenz zurückgegeben, die durch Durchlaufen definiert werden A. Um es besser zu verstehen, ist hier ein Beispiel mit den Längen der neu hinzugefügten Gruppen in Klammern:
A = [2, 3, 1]
N = 25
2: [[2], 2 ]
3: [ 2 ,[2], 3 , 3 ]
1: [ 2 , 2 ,[3], 3 , 1 , 1 , 1 ]
2: [ 2 , 2 , 3 ,[3], 1 , 1 , 1 , 2 , 2 , 2 ]
3: [ 2 , 2 , 3 , 3 ,[1], 1 , 1 , 2 , 2 , 2 , 3 ]
1: [ 2 , 2 , 3 , 3 , 1 ,[1], 1 , 2 , 2 , 2 , 3 , 1 ]
2: [ 2 , 2 , 3 , 3 , 1 , 1 ,[1], 2 , 2 , 2 , 3 , 1 , 2 ]
3: [ 2 , 2 , 3 , 3 , 1 , 1 , 1 ,[2], 2 , 2 , 3 , 1 , 2 , 3 , 3 ]
1: [ 2 , 2 , 3 , 3 , 1 , 1 , 1 , 2 ,[2], 2 , 3 , 1 , 2 , 3 , 3 , 1 , 1 ]
2: [ 2 , 2 , 3 , 3 , 1 , 1 , 1 , 2 , 2 ,[2], 3 , 1 , 2 , 3 , 3 , 1 , 1 , 2 , 2 ]
3: [ 2 , 2 , 3 , 3 , 1 , 1 , 1 , 2 , 2 , 2 ,[3], 1 , 2 , 3 , 3 , 1 , 1 , 2 , 2 , 3 , 3 , 3 ]
1: [ 2 , 2 , 3 , 3 , 1 , 1 , 1 , 2 , 2 , 2 , 3 ,[1], 2 , 3 , 3 , 1 , 1 , 2 , 2 , 3 , 3 , 3 , 1 ]
2: [ 2 , 2 , 3 , 3 , 1 , 1 , 1 , 2 , 2 , 2 , 3 , 1 ,[2], 3 , 3 , 1 , 1 , 2 , 2 , 3 , 3 , 3 , 1 , 2 , 2 ]
C: [ 2 , 2 , 3 , 3 , 1 , 1 , 1 , 2 , 2 , 2 , 3 , 1 , 2 , 3 , 3 , 1 , 1 , 2 , 2 , 3 , 3 , 3 , 1 , 2 , 2 ]
Hier ist ein weiteres Beispiel mit einem führenden 1:
A = [1, 2, 3]
N = 10
1: [[1]]
2: [ 1 ,[2], 2 ]
3: [ 1 , 2 ,[2], 3 , 3 ]
1: [ 1 , 2 , 2 ,[3], 3 , 1 , 1 , 1 ]
2: [ 1 , 2 , 2 , 3 ,[3], 1 , 1 , 1 , 2 , 2 , 2 ]
C: [ 1 , 2 , 2 , 3 , 3 , 1 , 1 , 1 , 2 , 2 ]
Wie Sie oben sehen können, wurde das Endergebnis in N = 10Elemente geschnitten . Das nth-Element sollte sein, wie lang die nth-Equal-Element-Gruppe ist, auch wenn das Element selbst zu der Gruppe gehört, auf die es verweist. Wie im obigen Fall 1bezieht sich der erste auf die erste solche Gruppe, die genau das ist 1, und der erste 2bezieht sich auf die zweite solche Gruppe, die damit beginnt.
Regeln
- Sie können davon ausgehen, dass
Aniemals zwei oder mehr aufeinanderfolgende gleiche Elemente vorhanden sind.Aenthalten kann , sobald eine ganze Zahl größer als, aber die ersten und letzten Elemente werden nicht gleich sein, undAmindestens 2 Elemente enthält ( zum Beispiel[1, 2, 2, 3],[2, 4, 3, 1, 2]und[3]sind nicht gegeben werde werden). Dies liegt daran, dass bei aufeinanderfolgenden gleichen Elementen das Endergebnis ein ungültiges Präfix für eine solche Sequenz gewesen wäre. - Sie können davon ausgehen, dass
Anur positive ganze Zahlen enthalten sind (da eine solche Sequenz ansonsten undefiniert wäre). - Sie können davon ausgehen, dass
Nes sich um eine nicht negative Ganzzahl (N >= 0) handelt. - Sie können nicht mehr Bedingungen als angefordert zurückgeben.
- Die Verwendung einer der Standardlücken ist strengstens untersagt.
- Sie können jede vernünftige E / A-Methode verwenden .
- Ihre Antwort muss nicht über die Grenzen der natürlichen Sprache hinaus funktionieren, theoretisch sollte Ihr Algorithmus jedoch für beliebig große Eingaben und ganze Zahlen funktionieren .
- Das ist Code-Golf , also gewinnt die kürzeste Antwort.
Testfälle
[5, 1, 2], 0 -> []
[2, 3, 1], 25 -> [2, 2, 3, 3, 1, 1, 1, 2, 2, 2, 3, 1, 2, 3, 3, 1, 1, 2, 2, 3, 3, 3, 1, 2, 2]
[1, 2, 3], 10 -> [1, 2, 2, 3, 3, 1, 1, 1, 2, 2]
[1, 2], 20 -> [1, 2, 2, 1, 1, 2, 1, 2, 2, 1, 2, 2, 1, 1, 2, 1, 1, 2, 2, 1]
[1, 3], 20 -> [1, 3, 3, 3, 1, 1, 1, 3, 3, 3, 1, 3, 1, 3, 3, 3, 1, 1, 1, 3]
[2, 3], 50 -> [2, 2, 3, 3, 2, 2, 2, 3, 3, 3, 2, 2, 3, 3, 2, 2, 3, 3, 3, 2, 2, 2, 3, 3, 3, 2, 2, 3, 3, 2, 2, 2, 3, 3, 3, 2, 2, 3, 3, 2, 2, 2, 3, 3, 3, 2, 2, 2, 3, 3]
[7, 4], 99 -> [7, 7, 7, 7, 7, 7, 7, 4, 4, 4, 4, 4, 4, 4, 7, 7, 7, 7, 7, 7, 7, 4, 4, 4, 4, 4, 4, 4, 7, 7, 7, 7, 7, 7, 7, 4, 4, 4, 4, 4, 4, 4, 7, 7, 7, 7, 7, 7, 7, 4, 4, 4, 4, 7, 7, 7, 7, 4, 4, 4, 4, 7, 7, 7, 7, 4, 4, 4, 4, 7, 7, 7, 7, 4, 4, 4, 4, 7, 7, 7, 7, 7, 7, 7, 4, 4, 4, 4, 4, 4, 4, 7, 7, 7, 7, 7, 7, 7, 4]
[1, 2, 3], 5 -> [1, 2, 2, 3, 3]
[2, 1, 3, 1], 2 -> [2, 2]
[1, 3, 5], 2 -> [1, 3]
[2, 3, 2, 4], 10 -> [2, 2, 3, 3, 2, 2, 2, 4, 4, 4]