Problema das Oito Rainhas (Random)
Publicado por N 01/02/2006
[ Hits: 10.147 ]
Um enigma para os fãs de xadrez é o problema das Oito Rainhas,
que exige o seguinte: é possível colocar oito rainhas em um
tabuleiro de xadrez vazio de modo que nenhuma esteja 'atacando'
alguma outra (isto é, sem que duas rainhas estejam na mesma linha,
na mesma coluna ou na mesma diagonal)?
Versão Random.
Nycholas de Oliveira e Oliveira - o_lalertom
#!/usr/bin/env python # -*- coding: utf-8 -*- # # Problema das Oito Rainhas. # Copyright (C) 2006 by Nycholas de Oliveira e Oliveira <nycholas@gmail.com> # # This program is free software; you can redistribute it and/or # modify it under the terms of the GNU General Public License # as published by the Free Software Foundation; either version 2 # of the License, or (at your option) any later version. # # <Este programa é software livre; você pode redistribuí-lo e/ou modificá-lo sob os # termos da Licença Pública Geral GNU conforme publicada pela Free Software Foundation; # tanto a versão 2 da Licença, como (a seu critério) qualquer versão posterior.> # # This program is distributed in the hope that it will be useful, # but WITHOUT ANY WARRANTY; without even the implied warranty of # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the # GNU General Public License for more details. # # <Este programa é distribuído na expectativa de que seja útil, porém, SEM NENHUMA # GARANTIA; nem mesmo a garantia implícita de COMERCIABILIDADE OU ADEQUAÇÃO A UMA # FINALIDADE ESPECÍFICA. Consulte a Licença Pública Geral do GNU para mais detalhes.> # # You should have received a copy of the GNU General Public License # along with this program; if not, write to the Free Software # Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. # # <Você deve ter recebido uma cópia da Licença Pública Geral do GNU junto com este # programa; se não, escreva para a Free Software Foundation, Inc., no endereço 59 # Temple Street, Suite 330, Boston, MA 02111-1307 USA.> # ######################################################### # NOME : Nycholas de Oliveira e Oliveira # # E-MAIL : nycholas@gmail.com # # ICQ : 114965471 # # MSN : o_lalertom@hotmail.com # # JABBER : nycholas@jabber.org # # TALK : nycholas@gmail.com # # DESCRICAO : Problema das Oito Rainhas # # LOCALIZACAO : Uberlândia - MG # # LOCALIZACAO : Brasil # ######################################################### import random class OitoRainhas: def __init__(self): print self.printBegin() self.run() #self.setVars() #self.setRainha(3, 2) def printBegin(self): p = \ " + Problema das Oito Rainhas\n" \ " * Copyright (C) 2006 by Nycholas de Oliveira e Oliveira <nycholas@gmail.com>\n\n" \ ">> Para melhor visualizar o conteúdo impresso em tela, o terminal deve esta setado com a coluna em 42.\n" return p def printRainha(self): p = \ "\n==========================================\n" \ " + " + str(len(self.posRainha)) + " Rainha\n\n" \ + str(self.t) return p def printEnd(self): p = \ "\n\n >> Nycholas de Oliveira e Oliveira - o_lalertom - nycholas@gmail.com" return p def setVars(self): self.TABULEIRO = \ "########\n" \ "########\n" \ "########\n" \ "########\n" \ "########\n" \ "########\n" \ "########\n" \ "########\n" self.VAZIO, self.ATAQUE, self.RAINHA = "#", "+", "*" self.posRainha, self.posValida = [], [] self.t = [list(line) for line in self.TABULEIRO.splitlines()] self.posValida = self.setPosValida() def setPosValida(self): l = [] for y in range(len(self.t)): for x in range(len(self.t)): l.append([x,y]) return l def setRainha(self, x=0, y=0): if 0 <= x <= 7 and 0 <= y <= 7: if self.t[x][y] == self.VAZIO: self.t[x][y] = self.RAINHA self.posRainha.append([x, y]) self.posValida.remove([x, y]) self.moveX(x, y) self.moveY(x, y) self.moveXYDir(x, y) self.moveXYEsq(x, y) print self.printRainha() def moveX(self, x=0, y=0): if 0 <= x <= 7: if self.t[x][y] == self.RAINHA: i = (map(lambda x: x == self.RAINHA, self.t[x])).index(True) self.t[x][:i] = list(len(self.t[x][:i])*self.ATAQUE) self.t[x][i+1:] = list(len(self.t[x][i+1:])*self.ATAQUE) for i in range(len(self.t[x])): if self.t[x][i] == self.ATAQUE: try: self.posValida.remove([x, i]) except ValueError: pass return True else: if self.moveX(x+1, y) or self.moveX(x-1, y): pass return False def moveY(self, x=0, y=0): if 0 <= y <= 7: if self.t[x][y] == self.RAINHA: for i in range(len(self.t)): if self.t[i][y] <> self.RAINHA: self.t[i][y] = self.ATAQUE try: self.posValida.remove([i, y]) except ValueError: pass return True else: if self.moveY(x, y+1) or self.moveX(x, y-1): pass return False def moveXYDir(self, x=0, y=0): if 0 <= x <= 7 and 0 <= y <= 7: if self.t[x][y] == self.RAINHA: try: for i in range(len(self.t[x])): if 0 <= (x+i) < len(self.t[x]) and 0 <= (y+i) < len(self.t[x]): if self.t[x+i][y+i] <> self.RAINHA: self.t[x+i][y+i] = self.ATAQUE try: self.posValida.remove([x+i, y+i]) except ValueError: pass finally: for i in range(len(self.t[x])): #print (x-i), (y-i), len(self.t[x]) if 0 <= (x-i) < len(self.t[x]) and 0 <= (y-i) < len(self.t[x]): if self.t[x-i][y-i] <> self.RAINHA: self.t[x-i][y-i] = self.ATAQUE try: self.posValida.remove([x-i, y-i]) except ValueError: pass return True else: if self.moveXYDir(x+1, y+1) or self.moveXYDir(x-1, y-1): pass return False def moveXYEsq(self, x=0, y=0): if 0 <= x <= 7 and 0 <= y <= 7: if self.t[x][y] == self.RAINHA: try: for i in range(len(self.t[x])): if 0 <= (x-i) < len(self.t[x]) and 0 <= (y+i) < len(self.t[x]): if self.t[x-i][y+i] <> self.RAINHA: self.t[x-i][y+i] = self.ATAQUE try: self.posValida.remove([x-i, y+i]) except ValueError: pass finally: for i in range(len(self.t[x])): if 0 <= (x+i) < len(self.t[x]) and 0 <= (y-i) < len(self.t[x]): if self.t[x+i][y-i] <> self.RAINHA: self.t[x+i][y-i] = self.ATAQUE try: self.posValida.remove([x+i, y-i]) except ValueError: pass return True else: if self.moveXYEsq(x+1, y-1) or self.moveXYEsq(x+1, y-1): pass return False def testVazio(self): r = False for i in range(8): if len(filter(lambda x: x == self.VAZIO, self.t[i])) > 0: r = True else: r = False return r def loop(self): try: for i in range(8): x = self.posValida[random.randrange(0, 7, 1)][0] y = self.posValida[random.randrange(0, 7, 1)][1] if [x, y] in self.posValida: self.setRainha(x, y) else: continue except IndexError: pass if len(self.posRainha) < 8 and self.testVazio() == True: self.loop() def run(self): self.setVars() self.setRainha() self.loop() if 0 <= len(self.posRainha) < 8 and self.testVazio() == False: self.run() else: print self.printEnd() if __name__ == "__main__": oitoRainhas = OitoRainhas()
Dicionário Ingles de expressões.
Inteligência artificial com Python e Shell Script
Compartilhando a tela do Computador no Celular via Deskreen
Como Configurar um Túnel SSH Reverso para Acessar Sua Máquina Local a Partir de uma Máquina Remota
Configuração para desligamento automatizado de Computadores em um Ambiente Comercial
Como renomear arquivos de letras maiúsculas para minúsculas
Imprimindo no formato livreto no Linux
Vim - incrementando números em substituição
Efeito "livro" em arquivos PDF
Como resolver o erro no CUPS: Unable to get list of printer drivers
Melhorando a precisão de valores flutuantes em python[AJUDA] (3)
Instalação Uefi com o instalador clássico do Mageia (1)
[Python] Automação de scan de vulnerabilidades
[Python] Script para analise de superficie de ataque
[Shell Script] Novo script para redimensionar, rotacionar, converter e espelhar arquivos de imagem
[Shell Script] Iniciador de DOOM (DSDA-DOOM, Doom Retro ou Woof!)
[Shell Script] Script para adicionar bordas às imagens de uma pasta