El parser!! No me canso de quitarme problemas leyendo la entrada con un poco de cuidado (incluso he tratado de correr el fichero de un puzle con el código de otro y esto ayuda a que nada que no tenga que pasar "pase"...
Leemos todos los "chunks" y de aquellos corruptos calculos su "score" an base al caracter que no cuadraba en el lexing.. Usamos un dict para las puntuaciones +
Me dá la risa porque este ejercicio se lo hemos puesto casi igual a los alumnos de "Estructuras de Datos" en el tema 1 "pilas" (la parte que pude dar esta año antes de lesionarme) Asi que voy a hacerlo un poco bonito q a alguno le puede "ilumnar". Empecemos con un poco de TDD.. +
Wrapper/worker y una pila para almacenar "aperturas" y compararlas con los cierres. si todo cuadra "bien" sino o bien falta entrada: "incompleto" o bien no cuadra con la pila: "corrupto" leed los comentarios y vereis claro el código (espero!) +
Probamos el fichero de test y el escore cuadra +
Atacamos el puzzle y aunque un tanto verboso la salida no deja lugar a dudas +
Trabajo limpio y sin problemas, aquí el TDD ha dados sus frutos y veremos luego que "tenemos gran parte de la segunda parte" avanzada.
"La parte contratante de la 1º parte..."
Con la informacion de la pila que extraeremos del parsing simplemente reconstruimos el "final perfecto" dandole la vuelta a la pila y convirtiendo aperturas en cierres. qué hemos necesitado para hacerlo? veamos.. +
Añadimos el estado de la pila y la entrada restante a las tuplas del resultado del "parsing". En realidad sólo necesitamos el estado de la pila, pues vamos a recrear el final de las cadenas invirtiendo la pila y transformando '([{<' en ')]}>' (en el función principal, claro!).. +
Probamos con el fichero de test.. +
y entonces atacamos el puzzle. Salida excelsa como siempre pero todo sin problemas.
El octavo de #AdventOfCode parte 2 en SQL. Un poco ñapas para mi gusto pero es lo que hay!
Empezamos como siempre..
Limpiamos linea alinea y separamos x, y, altura para cada arbol usando CTEs en secuencia.
Cruzamos cada arbol con su scan a derecha, izquierda, arriba y abajo con sub-consultas correlacionadas. Hay que cambair el orden de los que devuleven para que quedan en funcioón del punto de vista. Cada resultado se agrega en un array.
#AdventOfCode 5 Supply Stacks en SQL puro (PostgreSQL)
Si te gusta el SQL lo vas a flipar (creo) , sígueme en este triste historia (por lo de "La Roja") +
Empezamos como siempre, y toca cargar el fichero de test que ya tiene tela...
Empezamos enumerando las lineas del fichero (ya en la tabla de input), quedandonos con la parte de las pilas y calculando la longitud maxima de entre todas las líneas (por si caso no eran iguales)
Quien no sepa que esto que lea mis otros hilos porque ya va siendo lo mismo todo el rato
Tan facil que no lo voy a despiezar pues creo que se entiende de un vistazo y además esta comenetado. Convierte en rangos y comprueba inclusiones entre ellos.
Bueno, de vuelta al #AdventOfCode 3 Rucksack Reorganization
Empezamos leyendo los datos con ayuda de una tabla y restricciones adecuadas..
He creado una vista con la solución y así la reuso para pasar el test y luego el fichero de entrada del desafío.
Seguidamente os explico, aquí la muestro plegada junto con el código completo.
Empiezo mapeando las prioridades ['a'..'z'] -> [1..26] y ['A'..'Z'] -> [27..52] con dos consultas sencillas y el operador UNION ALL
Este año en la encuesta de evaluación docente me van a crujir los alumnos y seguramente las prácticas de la asignatura son lo más parecido a lo que demandan cuando recién aterrizados en el curro te quejas de lo que no visteis en la universidad
Les hemos hecho currar a base de bien primero un diseño con su modelo entidad relación y su diccionario de datos justificando cada dato cada dominio cada tipo y créeme que les hemos hechi pelear cada punto y cada coma lo mismo para el modelo relacional...
después nos hemos dado un conjunto de datos con muchos defectos han tenido que cargarlos en tablas y examinarlos y razonar sobre qué transformaciones o incluso qué modificaciones a su modelo original deberían hacer ( Y efectuarlas!)