Invirtiendo en Jaén
Tras amasar una inmensa fortuna en las empresas tecnológicas de su país, Comm O’Lhivas ha decidido dar un giro a su vida y dedicarse a negocios más campestres. Enamorado desde hace años del sur de España, ha puesto sus miras en los aceituneros de Jaén, y está decidido a comprar la mayor plantación de olivos que encuentre en la zona.
Siendo un hombre que consigue todo aquello que se propone, se ha hecho con los mapas del catastro, en los que el terreno se muestra troceado en parcelas cuadradas, todas del mismo tamaño. Las que están cultivadas con olivos aparecen de color verde, y el resto aparecen en blanco. Dado que no es un inversor que se conforme con negocios pequeños, necesita ahora decidir qué plantación es la más grande, para comprarla entera. Se considera que una plantación es un conjunto de parcelas con olivos situadas de tal modo que podemos ir de cualquier parcela a cualquier otra sin salir de la plantación, y moviéndonos únicamente en vertical o en horizontal.
Por ejemplo, en el siguiente mapa (donde cada parcela se ha representado mediante un cuadrado) la plantación más grande (marcada con puntos blancos) tiene 9 parcelas:
Entrada
La entrada estará compuesta por diversos casos de prueba. Para cada caso, la primera línea contendrá el número F de filas y el número C de columnas de parcelas que tiene el mapa (números entre 1 y 100). A continuación aparecerán F líneas, cada una con C caracteres. El espacio en blanco representa una parcela sin plantar, y el carácter # representa una parcela con olivos.
Salida
Para cada caso de prueba se escribirá en una línea independiente el número de parcelas de la plantación más grande.
Entrada de ejemplo
8 8
# # #
### #
####
#
# #
### ##
### ##
#
3 10
### ####
##
##########
Salida de ejemplo
9
15
Solución propuesta
import numpy as np
from itertools import product
def vacío(mapa):
vacío = True
for fila, columna in list(product(range(mapa.shape[0]), range(mapa.shape[1]))):
vacío = vacío and mapa[fila, columna] == ' '
return vacío
def calcular_contiguos(mapa, lista_puntos, inicio):
if mapa[inicio[0], inicio[1]] == ' ':
lista_puntos.remove(inicio)
return 0
elif mapa[inicio[0], inicio[1]] == '#':
mapa[inicio[0], inicio[1]] = ' '
lista_puntos.remove(inicio)
contiguos_fila = 0
contiguos_columna = 0
if [inicio[0] + 1, inicio[1]] in lista_puntos:
contiguos_fila = calcular_contiguos(mapa, lista_puntos, [inicio[0] + 1, inicio[1]])
if [inicio[0], inicio[1] + 1] in lista_puntos:
contiguos_columna = calcular_contiguos(mapa, lista_puntos, [inicio[0], inicio[1] + 1])
return 1 + contiguos_fila + contiguos_columna
if __name__ == '__main__':
soluciones = []
filas, columnas = [int(x) for x in input().split()]
while filas and columnas:
mapa = np.empty([filas, columnas], str)
for fila in range(filas):
mapa[fila, :] = [c for c in input()]
lista_parcelas = []
lista_puntos = [[x, y] for x, y in
list(product(range(mapa.shape[0]),
range(mapa.shape[1])))]
while not vacío(mapa):
lista_parcelas.append(calcular_contiguos(mapa, lista_puntos, lista_puntos[0]))
soluciones.append(max(lista_parcelas))
filas, columnas = [int(x) for x in input().split()]
for solución in soluciones:
print(solución)