LabVIEWForum.de - 5. LVF Rätsel mit Gewinnspiel

LabVIEWForum.de

Normale Version: 5. LVF Rätsel mit Gewinnspiel
Du siehst gerade eine vereinfachte Darstellung unserer Inhalte. Normale Ansicht mit richtiger Formatierung.
Seiten: 1 2 3 4
Wow. Schon die 60. Generation dauert bei mir knapp über 9 Sekunden...... O
OK, es sind da dann ja auch schon 12.680.852 (über 12 Millionen!) Elemente. Wink

Gruß Markus

' schrieb:Hallo!
Ich bin auch noch mit dabei. Da ich über das lange Wochenende weg bin, poste ich einfach mal mein Wurm-Vi.

Grüße
Andreas
Hallo,

hier also meine Beiträge zum Rätsel. Ich habe mich hauptsächlich auf eine schnelle Erzeugung mittels Zahlen-Array konzentriert, was mir auch in den letzten beiden Varianten (V10 & V12 in der llb) denke ich recht gut gelungen ist. Was dann bei großen Generationen sehr viel Zeit kostet, ist die Umwandlung des Arrays in einen String.
Prinzipiell habe ich immer dasselbe Prinzip angewandt, nämlich Vergleich aufeinanderfolgender Elemente. Ich wende also kein Vorwissen an, dass Zahlen > 3 nicht vorkommen können.
In der ersten hier hochgeladenen Variante wird nach einem Elementwechsel in einer While-Schleife gesucht, wie oft das Element noch hintereinander vorkommt. Parallel wird die nächste Generation per Build-Array-Funktionen erstellt.
In den drei anderen Varianten werden immer 2 aufeinanderfolgende Elemente verglichen. Bei Elementwechsel wird entsprechend die nächste Generation weitergebaut. Variante 9 arbeitet hierbei mit Build-Array-Aufrufen, etwas unübersichtlicher, aber deutlich schneller, wird es dann in V10. Hier sind die Build-Array durch Replace-Array-Subset-Aufrufe ersetzt. V12 ist gegenüber V10 dahingehend speicheroptimiert, dass sowohl das Array der letzten Generation als auch das gerade zu bauende innerhalb desselben Arrays gespeichert werden. V10&V12 sind wie schon gesagt sehr schnell, allerdings bremst die Erzeugung eines Strings zusätzlich zum Array am Ende das Ganze doch sehr aus.

Ich hab mal alles runtergespeichertfür Version 8.0, damit sich noch mehr die Lösungen anschauen können.
[attachment=6416]
[attachment=6417][attachment=6418]
[attachment=6419][attachment=6420]
[attachment=6422]

Ach ja, noch ein Nachtrag: Ab Generation 11 fangen alle weiteren Würmer nur noch mit den Zahlen "1113122113" "3113112221" und "1321132132" an. Diese Periodizität lässt sich sicher noch weiter ausbauen, aber für mehr hatte ich keine Lust mehr.

MfG, Jens
OKAY!

Erstmal gratulation Euch zwei beiden! Ich denke die Tasse ist verdient. Oder hat jemand Einwände?

Nun haben wir definitiv 2 VIs innerhalb der Zeit. Nun können wir ans Verbessern gehen.

Gruß
@Andreas: Ich finde deine Lösung echt toll. Bin vor allem sehr erstaunt, wie flott sie läuft, obwohl du ja dauernd den String und somit auch die String-Länge manipulierst.
Kleine Verbesserung habe ich:
[attachment=6430]
Du berechnest nämlich immer einen Wurm zuviel. Und außerdem kannst du deine While- gleich durch eine For-Schleife ersetzen.

@Mr.T: Danke für die Gratulation. Habe natürlich keine Einwände gegen die Verteilung der TassenSmile

MfG, Jens
Seiten: 1 2 3 4
Referenz-URLs