begin process at 2012 05 27 17:52:48
  Trouver un code source :
 
dans
 
Accueil > 

Code

 > 

Maths & Algorithmes

 > LE PROBLÈME DES 8 DAMES (14 CAVALIERS, ...)

LE PROBLÈME DES 8 DAMES (14 CAVALIERS, ...)




 Description

Le problème des 8 dames consiste à trouver comment placer 8 dames sur un échiquier classique (8*8) de telle sorte qu'aucune ne puisse prendre les autres...

J'ai trouvé ce problème sur wikipedia, mon programme comptes les solutions, mais peut aussi bien les afficher, suffit de le lui demander...

Source

  • #include <stdio.h>
  • #include <stdlib.h>
  • typedef struct {
  • int x, y;
  • } cases;
  • typedef struct {
  • char c[8][8];
  • } echiquier;
  • int myabs(int a){
  • return (a>=0)?a:-a;
  • }
  • int damesCanGo(cases a, cases b){
  • if (a.x==b.x || a.y==b.y){
  • return 1;
  • }else if (myabs(a.x-b.x) == myabs(a.y-b.y)){
  • return 1;
  • }else{
  • return 0;
  • }
  • }
  • int fousCanGo(cases a, cases b){
  • if (myabs(a.x-b.x) == myabs(a.y-b.y)){
  • return 1;
  • }else{
  • return 0;
  • }
  • }
  • int cavaliersCanGo(cases a, cases b){
  • int c, d;
  • c=myabs(a.x-b.x);
  • d=myabs(a.y-b.y);
  • if ((d==2 && c==1) || (d==1 && c==2)){
  • return 1;
  • }else{
  • return 0;
  • }
  • }
  • int roisCanGo(cases a, cases b){
  • int c, d;
  • c=myabs(a.x-b.x);
  • d=myabs(a.y-b.y);
  • if (c==1 && d==1){
  • return 1;
  • }else{
  • return 0;
  • }
  • }
  • void afficher(echiquier a){
  • int i, j;
  • for (j=0;j<10;j++){
  • printf("----");
  • }
  • printf("\n");
  • for (i=0;i<8;i++){
  • for (j=0;j<8;j++){
  • printf(" | %c", a.c[i][j]);
  • }
  • printf(" |\n");
  • for (j=0;j<10;j++){
  • printf("----");
  • }
  • printf("\n");
  • }
  • }
  • int sol(int nbr, int di, int dj, echiquier a, int (*fnc) (cases a, cases b)){
  • int i, j, k, l, m, n=0;
  • cases c, b;
  • if (nbr==0){
  • //afficher(a);
  • return 1;
  • }
  • nbr--;
  • for (i=di;i<8;i++){
  • for (j=dj;j<8;j++){
  • if (a.c[i][j]==' '){
  • m=0;
  • for (k=0;k<=di;k++){
  • for (l=0;l<8;l++){
  • if ((k!=i || l!=j ) && a.c[k][l]=='Q'){
  • c.x=i;
  • c.y=j;
  • b.x=k;
  • b.y=l;
  • if (fnc(c, b)){
  • m=1;
  • break;
  • }
  • }
  • }
  • if (m) break;
  • }
  • if (!m){
  • a.c[i][j]='Q';
  • n+=sol(nbr, i, j, a, fnc);
  • a.c[i][j]=' ';
  • }
  • }
  • }
  • dj=0;
  • }
  • return n;
  • }
  • echiquier new_echiquier(){
  • echiquier a;
  • int i, j;
  • for (i=0;i<8;i++){
  • for (j=0;j<8;j++){
  • a.c[i][j]=' ';
  • }
  • }
  • return a;
  • }
  • int main(){
  • echiquier a=new_echiquier();
  • printf ("il y a %d solutions au problÚme des 8 dames!\n",sol(8, 0, 0, a, damesCanGo));
  • printf ("il y a %d solutions au problÚme des 14 fous!\n",sol(14, 0, 0, a, fousCanGo));
  • printf ("il y a %d solutions au problÚme des 32 cavaliers!\n",sol(32, 0, 0, a, cavaliersCanGo));
  • printf ("il y a %d solutions au problÚme des 16 rois!\n",sol(16, 0, 0, a, roisCanGo));
  • return 42;
  • }
#include <stdio.h>
#include <stdlib.h>


typedef struct {
	int x, y;
} cases;

typedef struct {
	char c[8][8];
} echiquier;

int myabs(int a){
	return (a>=0)?a:-a;
}

int damesCanGo(cases a, cases b){
	if (a.x==b.x || a.y==b.y){
		return 1;
	}else if (myabs(a.x-b.x) == myabs(a.y-b.y)){
		return 1;
	}else{
		return 0;
	}
}
int fousCanGo(cases a, cases b){
	if (myabs(a.x-b.x) == myabs(a.y-b.y)){
		return 1;
	}else{
		return 0;
	}
}
int cavaliersCanGo(cases a, cases b){
	int c, d;
	c=myabs(a.x-b.x);
	d=myabs(a.y-b.y);
	if ((d==2 && c==1) || (d==1 && c==2)){
		return 1;
	}else{
		return 0;
	}
}
int roisCanGo(cases a, cases b){
	int c, d;
	c=myabs(a.x-b.x);
	d=myabs(a.y-b.y);
	if (c==1 && d==1){
		return 1;
	}else{
		return 0;
	}
}
void afficher(echiquier a){
	int i, j;
	for (j=0;j<10;j++){
		printf("----");
	}
	printf("\n");
	for (i=0;i<8;i++){
		for (j=0;j<8;j++){
			printf(" | %c", a.c[i][j]);
		}
		printf(" |\n");
		for (j=0;j<10;j++){
			printf("----");
		}
		printf("\n");
	}
}
int sol(int nbr, int di, int dj, echiquier a, int (*fnc) (cases a, cases b)){
	int i, j, k, l, m, n=0;
	cases c, b;
	if (nbr==0){
		//afficher(a);
		return 1;
	}
	nbr--;
	for (i=di;i<8;i++){
		for (j=dj;j<8;j++){
			if (a.c[i][j]==' '){
				m=0;
				for (k=0;k<=di;k++){
					for (l=0;l<8;l++){
						if ((k!=i || l!=j ) && a.c[k][l]=='Q'){
							c.x=i;
							c.y=j;
							b.x=k;
							b.y=l;
							if (fnc(c, b)){
								m=1;
								break;
							}
						}
					}
					if (m) break;
				}
				if (!m){
					a.c[i][j]='Q';
					n+=sol(nbr, i, j, a, fnc);
					a.c[i][j]=' ';
				}
			}
		}
		dj=0;
	}
	return n;
}
echiquier new_echiquier(){
	echiquier a;
	int i, j;
	for (i=0;i<8;i++){
		for (j=0;j<8;j++){
			a.c[i][j]=' ';
		}
	}
	return a;
}
int main(){
	echiquier a=new_echiquier();
	printf ("il y a %d solutions au problÚme des 8 dames!\n",sol(8, 0, 0, a, damesCanGo));
	printf ("il y a %d solutions au problÚme des 14 fous!\n",sol(14, 0, 0, a, fousCanGo));
	printf ("il y a %d solutions au problÚme des 32 cavaliers!\n",sol(32, 0, 0, a, cavaliersCanGo));
	printf ("il y a %d solutions au problÚme des 16 rois!\n",sol(16, 0, 0, a, roisCanGo));
	return 42;
}



 Sources du même auteur

[C ANSI] TAS (PRIORITY QUEUE)
Source avec Zip INTERPRETEUR BRAINFUCK
Source avec Zip Source avec une capture COMMENTAIRES DOXYGEN VERS VISUAL
Source avec Zip INTERPRETEUR D'UN LANGAGE PROCHE DU RPN
Source avec Zip FONCTIONS USUELLES (TRIGO) EN METAPROGRAMMATION

 Sources de la même categorie

Source avec Zip UN EXAMPLE D'APPLICATION EN CUDA DE L'ALGORITHME DE SCAN POU... par oguzaras
Source avec Zip Source avec une capture CHIFFREMENT DE VIGENERE par lajouad
Source avec Zip Source avec une capture ANALYSE SYNTAXIQUE par lajouad
Source avec Zip Source avec une capture STRUCTURE D'UNE MATRICE PAR LES LISTE LINÉAIRE (NON CONTUGUS... par benzarabel
Source avec Zip Source avec une capture DESSINER UNE ARBRE BINAIRE( MODE CONSOLE): par benzarabel

 Sources en rapport avec celle ci

Source avec Zip ALGORITHME ACO INTERFACE GTK par RyBeN
Source avec Zip Source avec une capture CHESSENDLOVE par pissendlove
PROBLÈME DE N DAMES par 0000blackbird0000
CAVALIERS SUR UN ÉCHIQUIER par pabbati
Source avec Zip RÉSOLUTION DU PROBLÈME DES 8 DAMES par The_Void

Commentaires et avis

Aucun commentaire pour le moment.

 Ajouter un commentaire


Discussions en rapport avec ce code source dans le forum

jeux d'echecs en c++ [ par ptitlouis68 ] Je dois realiser un projet de jeu d'echecs en c++ avec microsoft visual studio c++.Je recherche un code source de ce jeux ayant comme bibliotheque gra Jeu de dames - Min max [ par lacerto84 ] Salut tout le monde,Je commence en C++ et je souhaiterais réaliser un jeu.J'ai donc choisi de faire un jeu de dames avec IA.J'ai fait des recherches e Reseaux de neurones & Algorithmes genetiques [ par titchouno ] Salut tout le mondeJe voudrais sa voit si quelqu un a realiser un algo genethique avec des reseaux de neurones. Je me lance dans les reseaux de neuron erreurs [ par coucou747 ] Salut, j'aimerais un peu d'aide sur la signification des messages d'erreurs...Je ne maitrise pas vraiment les pointeurs et j'ai ça comme message :bash Algorithmes Génétiques: Aidez moi [ par boubs ] Bonjour,le problème: il s'agit d'optimiser une solution développée avec les AG.Le système prend en entrée un nombre un nombre de personnes et un nombr page turning effect [ par myrion ] Bonjour &#224; tous, Quelqu'un saurait-il me dire o&#249; trouver des algorithmes pour faire des effets de transition de pages comme on peut le voir Compression d image [ par k1roux ] Je suis etudiant en stage et mon projet est de compresser des images (peut importe l extension, JPEG.....) a l aide de differents algorithmes (RLC,RLC algo du jeu de dames [ par lesaleas ] je suis étudiante et je dois programmer un jeu de dames je m'y connait rien, aidez moi s'il vous plait!!!!! léa Waveform: distortion, chorus, flanger [ par Galmiza ] Salut, Je n'arrive pas à trouver les algorithmes qui permettent d'appliquer des effets comme la distortion, le chorus, etc.. sur des sons. Connaissez URGENT Jeu de dames en C [ par ledawa ] Bonjour je cherche un code source en language C d'un jeu de dames pouvant etre exécuté en mode terminal sous Xterm(Linux). Merci pour votre aide


Nos sponsors


Sondage...

Comparez les prix

CalendriCode

Mai 2012
LMMJVSD
 123456
78910111213
14151617181920
21222324252627
28293031   

Consulter la suite du CalendriCode

A découvrir



 
Développement réalisé par Nicolas SOREL (Nix) avec l'aide de : Cyril DURAND et Emmanuel (EBArtSoft), Merci à Vincent pour ses précieux conseils.
CodeS-SourceS.com© Toute reproduction même partielle est interdite sauf accord écrit du Webmaster
CodeS-SourceS.com© est une marque déposée tous droits réservés

Google Coop CodeS-SourceS Google Coop CodeS-SourceS
Temps d'éxécution de la page : 0,780 sec (4)

Nous contacter | Annoncer sur CodeS-SourceS | Mentions légales