| Homepage Computerstoff (Hauptseite) | [english] [français] |
Dies ist eine alte Knobel-Aufgabe, die gerne als Programmier-Übung genommen wird. Es geht darum, 8 Damen auf einem Schachbrett so anzuordnen, daß keine eine andere schlagen kann. Hier ist ein C-Programm, das aus rund 45 Zeilen Code (einschließlich Kommentaren) besteht. Gut 1/3 davon ist allerdings die Ausgabe. Es findet alle Lösungen des 8-Damen-Problems.
+----------------+ | <> | | <> | | <> | |<> | | <>| | <> | | <> | | <> | +----------------+ |
Es handelt sich um ein ANSI-C-Programm mit einer Text-Ausgabe, sollte also auf allen Betriebssytemen laufen und mit allen C-Compilern übersetzt werden können.
Download: damen.c (774Byte) [Der gestrippte Code ist ca. 3,5K groß.]
Hier ist das Programm auch nochmal zur Ansicht:
#include <stdio.h>
#include <stdlib.h>
int x[8]; /* x[i] = x coordinate of queen in row i. */
/* prints field */
void print ()
{
int i,j;
printf ("+----------------+\n");
for (i=0; i<8; i++) {
printf ("|");
for (j=0; j<8; j++)
if (j==x[i]) printf ("<>");
else printf (" ");
printf ("|\n");
}
printf ("+----------------+\n\n");
}
/* tests, whether (ix, iy) is beaten by queens 0...(iy-1) */
int is_free (int ix, int iy)
{
int i;
for (i=0; i<iy; i++)
if ((x[i]==ix) || (abs(x[i]-ix)==abs(i-iy))) return 0;
return 1;
}
/* tries to place queen n on row n */
void try (int n)
{
int i;
if (n==8) print();
else
for (i=0; i<8; i++)
if (is_free(i,n)) {
x[n]=i;
try (n+1);
}
}
int main ()
{
try (0);
return 0;
}
| Homepage Computerstoff (Hauptseite) | by Michael Becker, 2/2002. Letzte Änderung 4/2003 |