Jogo da velha reverso
Publicado por Djames Suhanko 12/12/2008
[ Hits: 6.784 ]
Homepage: www.phantomsystem.com.br
Um jogo da velha que você deve obrigar o computador a ganhar.
Dessa vez, sem gambiarra de "goto", usando apenas funções recursivas.
#ifdef HAVE_CONFIG_H #include <config.h> #endif #include <stdio.h> #include <stdlib.h> int main(int argc, char *argv[]) { int i; // As onze linhas que compoe a matriz // Linha 3 e 6 sao preenchidas por "_" // Indices de pipe: 5 e 11 // As linhas com 18 posicoes sao para coordenadas numericas char linha1[17], linha2[18], linha3[17], linha4[17], linha5[18], linha6[17]; char linha7[17], linha8[18], linha9[17]; //Definicao das coordenadas //Se limitarmos em 2 casas, havera erro se a digitacao passar de duas posicoes //Deixar esse excesso elimina tal bug char posicao[10]; char vez = 'X'; /* //Zeras as posicoes char zera(){ linha2[2] = ' '; linha2[8] = ' '; linha2[14] = ' '; linha5[2] = ' '; linha5[8] = ' '; linha5[14] = ' '; linha8[2] = ' '; linha8[8] = ' '; linha8[14] = ' '; } zera(); */ char matriz(){ system("clear"); //imprime a matriz linha2[17] = '1'; linha5[17] = '2'; linha8[17] = '3'; printf(" A B C\n"); for (i=0;i<17;i++) { printf("%c", linha1[i]); } printf("\n"); for (i=0;i<18;i++) { printf("%c", linha2[i]); } printf("\n"); for (i=0;i<17;i++) { printf("%c", linha3[i]); } printf("\n"); for (i=0;i<17;i++) { printf("%c", linha4[i]); } printf("\n"); for (i=0;i<18;i++) { printf("%c", linha5[i]); } printf("\n"); for (i=0;i<17;i++) { printf("%c", linha6[i]); } printf("\n"); for (i=0;i<17;i++) { printf("%c", linha7[i]); } printf("\n"); for (i=0;i<18;i++) { printf("%c", linha8[i]); } printf("\n"); for (i=0;i<17;i++) { printf("%c", linha9[i]); } printf("\n"); } //Gera numeros aleatorios de 1 a 9 //Computador joga int j=0; int computador(){ int myrand( int N ) { return random() % N; } unsigned int seed; seed=time(0); srandom(seed); int compopt = random()%10; if (compopt == 0) { compopt = 1; } int numeros[10]; numeros[j] = compopt; //Esse printf abaixo debuga o random printf("%d",numeros[j]); int x; if (j != 0) { for (x=j;x>-1;x--) { if (j != 0) { if (numeros[j] == numeros[j-1]) { sleep(1); computador(); } j = j-1; } } } j = j+1; //Posicoes 1 2 e 3 da primeira linha if (compopt == 1) { if (linha2[2] == '*' || linha2[2] == 'X') { sleep(1); computador(); } else { linha2[2] = vez; } } else if (compopt == 2) { if (linha2[8] == '*' || linha2[8] == 'X') { sleep(1); computador(); } else { linha2[8] = vez; } } else if (compopt == 3) { if (linha2[14] == '*' || linha2[14] == 'X') { sleep(1); computador(); } else { linha2[14] = vez; } } // Posicoes 1 2 e 3 da segunda linha else if (compopt == 4) { if (linha5[2] == '*' || linha5[2] == 'X') { sleep(1); computador(); } else { linha5[2] = vez; } } else if (compopt == 5) { if (linha5[8] == '*' || linha5[8] == 'X') { sleep(1); computador(); } else { linha5[8] = vez; } } else if (compopt == 6) { if (linha5[14] == '*' || linha5[14] == 'X') { sleep(1); computador(); } else { linha5[14] = vez; } } //Posicoes 1 2 e 3 da terceira linha else if (compopt == 7) { if (linha8[2] == '*' || linha8[2] == 'X') { sleep(1); computador(); } else { linha8[2] = vez; } } else if (compopt == 8) { if (linha8[8] == '*' || linha8[8] == 'X') { sleep(1); computador(); } else { linha8[8] = vez; } } else if (compopt == 9) { if (linha8[14] == '*' || linha8[14] == 'X') { sleep(1); computador(); } else { linha8[14] = vez; } } }//fim da funcao //humano joga char humano(){ printf("Entre com a coordenada: >> "); fflush(NULL); scanf("%s",&posicao); if (!strcmp(posicao,"a1")) { if (!(linha2[2] == '*' || linha2[2] == 'X')) { linha2[2] = '*'; } else { printf("Casa ocupada. tente de novo\n"); humano(); } } else if (!strcmp(posicao,"b1")) { if (!(linha2[8] == '*' || linha2[8] == 'X')) { linha2[8] = '*'; } else { printf("Casa ocupada. tente de novo\n"); humano(); } } else if (!strcmp(posicao,"c1")) { if (!(linha2[14] == '*' || linha2[14] == 'X')) { linha2[14] = '*'; } else { printf("Casa ocupada. tente de novo\n"); humano(); } } else if (!strcmp(posicao,"a2")) { if (!(linha5[2] == '*' || linha5[2] == 'X')) { linha5[2] = '*'; } else { printf("Casa ocupada. tente de novo\n"); humano(); } } else if (!strcmp(posicao,"b2")) { if (!(linha5[8] == '*' || linha5[8] == 'X')) { linha5[8] = '*'; } else { printf("Casa ocupada. tente de novo\n"); humano(); } } else if (!strcmp(posicao,"c2")) { if (!(linha5[14] == '*' || linha5[14] == 'X')) { linha5[14] = '*'; } else { printf("Casa ocupada. tente de novo\n"); humano(); } } else if (!strcmp(posicao,"a3")) { if (!(linha8[2] == '*' || linha8[2] == 'X')) { linha8[2] = '*'; } else { printf("Casa ocupada. tente de novo\n"); humano(); } } else if (!strcmp(posicao,"b3")) { if (!(linha8[8] == '*' || linha8[8] == 'X')) { linha8[8] = '*'; } else { printf("Casa ocupada. tente de novo\n"); humano(); } } else if (!strcmp(posicao,"c3")) { if (!(linha8[14] == '*' || linha8[14] == 'X')) { linha8[14] = '*'; } else { printf("Casa ocupada. tente de novo\n"); humano(); } } else { printf("Opcoes validas:\n"); printf("a1,a2,a3,b1,b2,b3,c1,c2,c3\n"); printf("Tente novamente:\n"); humano(); } } //Preenche as posicoes de pipe for (i=5;i<12;i++) { if (i == 5 || i == 11) { linha1[i] = '|'; linha2[i] = '|'; linha3[i] = '|'; linha4[i] = '|'; linha5[i] = '|'; linha6[i] = '|'; linha7[i] = '|'; linha8[i] = '|'; linha9[i] = '|'; } } //Preenche as linhas 3 e 6 for (i=0;i<17;i++) { if (i == 5 || i == 11) { i = i+1; } linha3[i] = '_'; linha6[i] = '_'; } // Preenche os espacos em branco de todas as linhas for (i=0;i<17;i++) { if(i == 5 || i == 11) { i = i+1; } linha1[i] = ' '; linha2[i] = ' '; linha4[i] = ' '; linha5[i] = ' '; linha7[i] = ' '; linha8[i] = ' '; linha9[i] = ' '; } //imprime a matriz //linha2[2] = '*'; //linha2[8] = '*'; //linha2[14] = '*'; matriz(); int a; for (a=0;;a++) { humano(); sleep(1); computador(); sleep(1); matriz(); } }
Jogo da cobrinha (Snake II) refeito em C e C++
Teoria do Caos - (Equação Logística)
Calculadora elementar com ponto flutuante
Simulador do Sorteio da Mega Sena
Nenhum comentário foi encontrado.
Passkeys: A Evolução da Autenticação Digital
Instalação de distro Linux em computadores, netbooks, etc, em rede com o Clonezilla
Título: Descobrindo o IP externo da VPN no Linux
Armazenando a senha de sua carteira Bitcoin de forma segura no Linux
Enviar mensagem ao usuário trabalhando com as opções do php.ini
Instalando Brave Browser no Linux Mint 22
vídeo pra quem quer saber como funciona Proteção de Memória:
Encontre seus arquivos facilmente com o Drill
Mouse Logitech MX Ergo Advanced Wireless Trackball no Linux
Compartilhamento de Rede com samba em modo Público/Anônimo de forma simples, rápido e fácil
Como abrir o pycharm no linux (2)
VMs e Interfaces de Rede desapareceram (12)