begin process at 2012 02 12 07:15:25
  Trouver un code source :
 
dans
 
Accueil > 

Code

 > 

Maths & Algorithmes

 > JEU HANOI EN C [VC 6.0]

JEU HANOI EN C [VC 6.0]


 Information sur la source

Note :
10 / 10 - par 1 personne
10,00 / 10

  • 1

  • 2

  • 3

  • 4

  • 5

  • 6

  • 7

  • 8

  • 9

  • 10
Catégorie :Maths & Algorithmes Niveau :Débutant Date de création :01/10/2002 Date de mise à jour :01/10/2002 10:50:11 Vu :4 468

Auteur : MegaMickx

Ecrire un message privé
Commentaire sur cette source (2)
Ajouter un commentaire et/ou une note

 Description


Source

  • #include<stdio.h>
  • #include<string.h>
  • #include<memory.h>
  • int nb,tab1[10],tab2[10],tab3[10];
  • void affichage() //int nb,int *tab1,int *tab2,int *tab3)
  • {
  • int i,w,l;
  • w=nb;
  • printf("\n");
  • for (l=9;l>=0;l--)
  • {
  • for (i=0;i<10-tab1[l];i++)
  • {
  • printf(" ");
  • }
  • for (i=0;i<tab1[l];i++)
  • {
  • printf("%c",177);
  • }
  • printf("%c",179);
  • for (i=0;i<tab1[l];i++)
  • {
  • printf("%c",177);
  • }
  • for (i=0;i<10-tab1[l];i++)
  • {
  • printf(" ");
  • }
  • for (i=0;i<10-tab2[l];i++)
  • {
  • printf(" ");
  • }
  • for (i=0;i<tab2[l];i++)
  • {
  • printf("%c",177);
  • }
  • printf("%c",179);
  • for (i=0;i<tab2[l];i++)
  • {
  • printf("%c",177);
  • }
  • for (i=0;i<10-tab2[l];i++)
  • {
  • printf(" ");
  • }
  • for (i=0;i<10-tab3[l];i++)
  • {
  • printf(" ");
  • }
  • for (i=0;i<tab3[l];i++)
  • {
  • printf("%c",177);
  • }
  • printf("%c",179);
  • for (i=0;i<tab3[l];i++)
  • {
  • printf("%c",177);
  • }
  • for (i=0;i<10-tab3[l];i++)
  • {
  • printf(" ");
  • }
  • //_getch();
  • printf("\n");
  • }
  • }
  • void deplacement(int *tab1,int *tab2,int *tab3,int n)
  • {
  • int i,y;
  • if (n>0)
  • {
  • deplacement(tab1,tab3,tab2,n-1);
  • for(i=9;i>0 && tab1[i]==0;i--);
  • if (tab1[i]!=0)
  • {
  • y=tab1[i];
  • tab1[i]=0;
  • //printf("y= %d",y);
  • for(i=0;i<10 && tab2[i]!=0;i++);
  • tab2[i]=y;
  • }
  • affichage(); //n,tab3,tab2,tab1);
  • getchar();
  • deplacement(tab3,tab2,tab1,n-1);
  • }
  • }
  • void main()
  • {
  • int w,nb,i;
  • memset(tab1,0,10*sizeof(int));
  • memset(tab2,0,10*sizeof(int));
  • memset(tab3,0,10*sizeof(int));
  • printf("Saisir nb d anneaux (max 10) : ");
  • scanf("%d",&nb);
  • w=nb;
  • for(i=0;i<10;i++)
  • {
  • tab1[i]=w;
  • if (w>0)
  • {
  • w=w-1;
  • }
  • }
  • if(nb<=10)
  • {
  • //affichage(nb,tab1,tab2,tab3);
  • deplacement(tab1,tab2,tab3,nb);
  • }
  • }
#include<stdio.h>
#include<string.h>
#include<memory.h>

int nb,tab1[10],tab2[10],tab3[10];

void affichage()  //int nb,int *tab1,int *tab2,int *tab3)
{
	int i,w,l;
w=nb;
    printf("\n");
	for (l=9;l>=0;l--)
	{
		for (i=0;i<10-tab1[l];i++)
		{
			printf(" ");
		}
		for (i=0;i<tab1[l];i++)
		{
			printf("%c",177);
		}
		printf("%c",179);
		for (i=0;i<tab1[l];i++)
		{
			printf("%c",177);
		}
		for (i=0;i<10-tab1[l];i++)
		{
			printf(" ");
		}

		for (i=0;i<10-tab2[l];i++)
		{
			printf(" ");
		}
		for (i=0;i<tab2[l];i++)
		{
			printf("%c",177);
		}
		printf("%c",179);
		for (i=0;i<tab2[l];i++)
		{
			printf("%c",177);
		}
		for (i=0;i<10-tab2[l];i++)
		{
			printf(" ");
		}

		for (i=0;i<10-tab3[l];i++)
		{
			printf(" ");
		}
		for (i=0;i<tab3[l];i++)
		{
			printf("%c",177);
		}
		printf("%c",179);
		for (i=0;i<tab3[l];i++)
		{
			printf("%c",177);
		}
		for (i=0;i<10-tab3[l];i++)
		{
			printf(" ");
		}
	//_getch();
	
		printf("\n");
	}		
}

void deplacement(int *tab1,int *tab2,int *tab3,int n)
{
	int i,y;
	if (n>0)
	{
		deplacement(tab1,tab3,tab2,n-1);
		for(i=9;i>0 && tab1[i]==0;i--);
		if (tab1[i]!=0)
		{
			y=tab1[i];
			tab1[i]=0;
		//printf("y= %d",y);
			for(i=0;i<10 && tab2[i]!=0;i++);		
			tab2[i]=y;			
		}
		affichage(); //n,tab3,tab2,tab1);
		getchar();
		deplacement(tab3,tab2,tab1,n-1);
	}
}

void main()
{
	int w,nb,i;
	memset(tab1,0,10*sizeof(int));
	memset(tab2,0,10*sizeof(int));
	memset(tab3,0,10*sizeof(int));

	printf("Saisir nb d anneaux (max 10) : ");
	scanf("%d",&nb);
	w=nb;
	for(i=0;i<10;i++)
	{
		tab1[i]=w;
		if (w>0)
		{ 
			w=w-1;
		}
	}

	
	if(nb<=10)
	{
		//affichage(nb,tab1,tab2,tab3);
		deplacement(tab1,tab2,tab3,nb);
	}
	
}

 Conclusion

Faut appuyer sur 'entrer' pour avancer d'une étape à l'autre


 Sources du même auteur

CONVERTISSEUR EUROS/FRANCS - FRANCS/EUROS

 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

Commentaires et avis

Commentaire de GoldenEye le 04/10/2002 10:57:54

Voilà ma proposition:

#include &lt;stdio.h&gt;

void hanoi(int n, int f, int v, int t){
  if (n &gt; 0) {
    hanoi(n-1, f, t, v);
    printf("De %d vers %d
", f, t);
    hanoi(n-1, v, f, t);
  }
}

int main(int argc,int *argv){
  hanoi(argv[1], 1, 2, 3);
  return 0;
}

Commentaire de fixerpl le 05/06/2006 02:22:54

cool

 Ajouter un commentaire




Nos sponsors


Sondage...

Comparez les prix

CalendriCode

Février 2012
LMMJVSD
  12345
6789101112
13141516171819
20212223242526
272829    

Consulter la suite du CalendriCode

 
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,952 sec (3)

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