Prinzipielle Grenzen der Berechenbarkeit: Unterschied zwischen den Versionen
K (→Abzählbarkeit) |
K (→Gödelisierung) |
||
Zeile 51: | Zeile 51: | ||
{{Aufgabe-Mathe| | {{Aufgabe-Mathe| | ||
Nun werden die 26 Buchstaben des Alphabets wie folgt kodiert: | Nun werden die 26 Buchstaben des Alphabets wie folgt kodiert: | ||
− | Den 26 Buchstaben des Alphabets wird jeweils eine eindeutige Zahl zwischen 1 und 26 zugeordnet. Ein Wort wird nun mit fortlaufenden Primzahlpotenzen kodiert, also wenn a die Zahl 1, b die Zahl 2, c die Zahl 3 zugeordnet wird, dann wird das Wort abbca wie folgt kodiert: | + | Den 26 Buchstaben des Alphabets wird jeweils eine eindeutige Zahl zwischen 1 und 26 zugeordnet. Ein Wort wird nun mit fortlaufenden Primzahlpotenzen kodiert, also wenn a die Zahl 1, b die Zahl 2, c die Zahl 3 zugeordnet wird, dann wird das Wort '''abbca''' wie folgt kodiert: |
* a ist der erste Buchstabe des Wortes und 2 die erste Primzahl. Also wird das a mit <math>2^1=2</math> kodiert. | * a ist der erste Buchstabe des Wortes und 2 die erste Primzahl. Also wird das a mit <math>2^1=2</math> kodiert. |
Version vom 20. September 2009, 18:55 Uhr
Inhaltsverzeichnis |
Abzählbarkeit
Eine Menge nennt man abzählbar, wenn sie entweder leer ist () oder es eine Funktion gibt, die surjektiv ist (jedes Element aus ist das Bild von mindestens einer natürlichen Zahl).
Beispiele für abzählbare Mengen:
- die Menge der natürlichen Zahlen
- die Primzahlen
- die Menge der ganzen Zahlen
- jede endliche Menge
- die Menge der rationalen Zahlen
Beispiele für nicht abzählbare Mengen:
- die Menge der reellen Zahlen
- die Potenzmenge der natürlichen Zahlen , also die Menge aller Teilmengen der natürlichen Zahlen
Programme sind eine endliche Folge von Wörtern über einem endlichen Alphabet (in der Praxis meist der ASCII-Code). Schreibt man den kompletten Programmtext in eine Zeile, so kann man die einzelnen Programme zunächst der Länge nach ordnen. Innerhalb der Programme einer festen Länge ordnet man diese lexikographisch. Damit kann man folgern, dass die Menge der Programme abzählbar ist.
Aufzählbarkeit
Berechenbarkeit
Gödelisierung
Mittels der sogenannten Gödelisierung lassen sich beliebige Eingabedaten in natürliche Zahlen umwandeln. Diese Vorgehensweise wird häufig in der theoretischen Informatik verwendet, da sich Algorithmen dadurch auf Funktionen über den natürlichen Zahlen abbilden lassen. Dafür gibt es verschiedenste Verfahren. Man fasst solch ein Verfahren als Abbildung von der Menge der Programme in die Menge der natürlichen Zahlen auf: . Die Abbildung muss dabei noch einige Bedingungen erfüllen:
- muss injektiv sein, d.h. jede natürliche Zahl darf höchstens das Bild von einem Programm sein; aber nicht jede natürliche Zahl muss auch ein Programm sein
- Die Bildmenge muss entscheidbar sein, es muss also einen Algorithmus der Ja ausgibt, wenn die Zahl einem Programm entspricht und Nein, wenn es sich um kein Programm handelt.
- Die Umkehrfunktion muss berechenbar sein, d.h. man muss aus der natürlichen Zahl auch wieder das Programm bekommen können.
Die 26 Buchstaben des Alphabets werden mit den Zahlen 1 bis 26 kodiert. Damit könnte man ein geschriebenes Wort als Zahl schreiben. Dekodiere die Zahl "26235945212097"! Welche Buchstabenfolge erhält man nach dem Dekodieren?
Möglichkeiten für das dekodierte Wort sind z.B.: ZWEIDEUTIG oder BFBCEIDEBATIG oder ...
|
Nun werden die 26 Buchstaben des Alphabets wie folgt kodiert: Den 26 Buchstaben des Alphabets wird jeweils eine eindeutige Zahl zwischen 1 und 26 zugeordnet. Ein Wort wird nun mit fortlaufenden Primzahlpotenzen kodiert, also wenn a die Zahl 1, b die Zahl 2, c die Zahl 3 zugeordnet wird, dann wird das Wort abbca wie folgt kodiert:
Multipliziert man diese Zahlen miteinander, erhält man die Zahl . Da die Primfaktorzerlegung eindeutig ist, wenn man die Primzahlpotenzen aufsteigend ordnet, kann man aus jeder Zahl das zugehörige Wort erzeugen. Welche Buchstabenfolge erhält man, wenn man die Zahl dekodiert?
Das dekodierte Wort lautet: INFORMATIK.
|
Nun werden die 26 Buchstaben des Alphabets mit den Zahlen 01 bis 26 kodiert. Schreibt man die kodierten Buchstaben hintereinander, so erhält man eine Zahl. Dekodiere die Zahl 26230509060512121519.
Das dekodierte Wort lautet: ZWEIFELLOS
|
Welches Verfahren eignet sich für eine Gödelisierung? (!Kodierung mit Zahlen 1 bis 26) (Kodierung mit Zahlen 01 bis 26) (Kodierung mit Primzahlpotenzen)(!Keines der Verfahren)
Fleißige Biber
Halte-Problem
Die Schüler der Kollegstufe besuchen verschiedene Kurse. Jeder Kurs findet einmal pro Woche statt. Belegt ein Schüler zwei Kurse, so dürfen diese nicht gleichzeitig stattfinden. Kann man mit verschiedenen Terminen auskommen? Erstelle hierzu eine Graphen, wobei ein Knoten einem Kurs entspricht. Zwei Knoten werden genau dann miteinander verbunden, wenn ein Schüler die beiden entsprechenden Kurse besucht. Man kann die Aufgabe als sogenanntes k-Farbproblem auffassen. |