Zur Palindromseite,
auf der mit
Dezimalzahlen
gearbeitet und das
"klassische 196er-Problem"
beschrieben wird
Eine Palindrom-Zahl kann "von rechts oder links gelesen" werden (diese Aussage gilt natürlich auch für "Wort-Palindrome"). Das hier behandelte Problem wird zunächst mit Dezimalzahlen erläutert:
Man nehme eine beliebige positive ganze Zahl (z. B.: 83), schreibe die Ziffern in umgekehrter Reihenfolge auf (38), addiere die beiden Zahlen (83 + 38 = 121). Wenn das Ergebnis nicht gleich ein Palindrom ist, setze man das Spielchen fort (siehe nebenstehendes Beispiel für die Zahl 249), bis das Ergebnis ein Palindrom ist.
Das funktioniert auch mit Binärzahlen: Wenn man zum Beispiel mit der Binärzahl 11111001 startet (entspricht der Dezimalzahl 249) dann landet man nach 10 Inversionen beim Palindrom 110001101100011.
Das nachfolgende Script führt diese Rechnung aus, wobei die Startzahl binär oder dezimal (wird dann umgerechnet) eingegeben werden kann. Man probiere es mit beliebigen Startzahlen:
Nein, durchaus nicht. Selbst im Bereich der Binärzahlen von 1 bis 100000 (entspricht der der Dezimalzahl 32) gibt es drei Zahlen, die sich hartnäckig widersetzen.
Das folgende Script untersucht einen Zahlenbereich von "Anfang" bis "Ende" darauf, wie viele Inversionen benötigt werden, bis ein Palindrom entsteht. Vorsichtshalber wird wieder eine obere Grenze "Maximale Inversionen" vorgegeben, bei deren Erreichen die Rechnung abgebrochen wird (warum gerade die Voreinstellung 1200 dafür vorgesehen ist, wird weiter unten deutlich). Man probiere zum Beispiel mal den Bereich von 100000 (dezimal: 32) bis 1000000 (dezimal: 64), und man stellt fest, dass es entweder sehr schnell geht oder aber zum Abbruch führt:
Eingabe als Binärzahl Dezimalzahl |
Maximale Inversionen pro Startzahl |
|||
Anfang: | (Dezimalzahl): | |||
Ende: |
Bereits bei relativ kleinen Binärzahlen entsteht nach dem beschriebenen Algorithmus kein Palindrom. Schon die 10110 (dezimal:22) weigert sich hartnäckig. Das ist deshalb überraschend, weil beim Arbeiten im Dezimalsystem die 196 die erste Zahl ist, für die es bisher nicht gelungen ist, ein Palindrom auf dem beschriebenen Weg zu erzeugen.
Die sich dabei aufdrängende Frage ist, ob man nur nicht hartnäckig genug probiert hat, es könnte ja bei ausreichend vielen Schritte schließlich doch ein Palindrom entstehen. Das so genannte "196er-Problem" hat zahlreiche Spezialisten herausgefordert, man hat es nicht geschafft, ein Palindrom zu erzeugen. Aber auch der Gegenbeweis, dass das auch für beliebig viele Schritte gilt, steht aus.
Vieles spricht dafür, dass es tatsächlich Startzahlen gibt, für die der beschriebene Algorithmus nicht zu einem Palindrom führt. Weil es aber für die anderen Zahlen relativ schnell geht, ist eine andere Frage interessant geworden: Welche Zahl sträubt sich besonders lange, um schließlich doch zu einem Palindrom zu führen.
Jason Doucette aus Kanada hat diese Frage für die Dezimalzahlen jahrelang untersucht und sogar einen sehr schönen Namen für das Problem gefunden: "Longest Delayed Palindrome". Seine Ergebnisse einschließlich seines "Weltrekords" habe ich hier kurz zusammengestellt.
Auch für die Binärzahlen ist diese Frage intensiv untersucht worden. Hier heißt der Weltrekordler Karl Hovekamp, der auch zahlreiche andere Palindrom-Probleme in unterschiedlichen Zahlensystemen auf seiner interessanten Internet-Site behandelt. Der von ihm angegebene Rekord zum "Longest Delayed Palindrom" im binären Zahlensystem lautet (die Rekordzahl wurde am 5.05.05 gefunden):
Die 102-stellige Startzahl
(entspricht der Dezimalzahl 3796617722816690185920388040579) ergibt nach 1194 Inversionen dieses 791-stellige Palindrom:
111111110000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000
000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000
000000000000000000000000000000000000000000000000000000000011111111000000000000000000000000000000000000
000000000000000000000000000000000000000000000000000000000000000000000000000000000011110000000111100000
000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000
000000000001111111100000000000000000000000000000000000000000000000000000000000000000000000000000000000
000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000
00000000000000000000000000000000000000000000000000000000000000000000011111111.
Man kann diesen imponierenden Rekord leicht mit dem oben zu findenden Script überprüfen (am einfachsten ist es, die Dezimalzahl mit "Copy-and-Paste" aufzunehmen und in das Eingabefeld zu bringen). Nach wenigen Sekunden dürfte Ihr Bildschirm so voller Einsen und Nullen sein, wie er es vorher wahrscheinlich noch nie war.
Karl Hovekamp hat sich auch eine sehr hübsche Visualisierung für die Berechnung ausgedacht, die für das genannte Beispiel so aussieht:
Jede der 1194 Zahlen wird durch eine vertikale Pixelreihe repräsentiert. Die schwarzen und weißen Pixel kennzeichnen Ziffern, für die bereits das spiegelbildliche Pendant existiert, schwarze Pixel stehen für eine 0, weiße für eine 1.