![]() |
Ayuda con algoritmo para buscar capitulos faltantes en una lista
Hola a todos
Pues dado un listado de archivos de novelas, necesito saber cuales capitulos faltan. - En una carpeta estan los archivos, que cada uno corresponde a un capitulo de la novela - El nombre del archivo (novela) puede tener una de estas nomenclaturas: ## - Nombre de la nonvela Nombre de la nonvela - ## donde ##, es el numero del capitulo. El objetivo es recorrer todos esos archivos y comprobar que todos los capitulos esten consecutivos hasta el final, que el ultimo capitulo seria el total de archivos en la carpeta. Si faltara algun capitulo, lo guardo en una variable para mostrala despues. Alguna idea de como realizar este proceso? |
Como saber los numeros faltantes en una lista consecutiva
Pues la forma de obtener los numeros de capitulos ya la tengo, en una cadena los almaceno separados por comas.
Lo que necesito saber es, de esa lista de numeros consecutivos ordenada, cuales son los numeros que faltan |
Quizás una forma simple sea guardar los números de capitulo que encuentras en la carpeta en un TList y aplicar un Short (de menor a mayor). Luego los recorres, si el número de capitulo no coincide con el indice + 1, ese te falta. Puedes hacer algo simlilar con un TStringList y CustomSort.
Saludos. |
Cita:
Pues estuve analizando esa forma y para el 1 faltante funciona, pero cuando hay mas, o cuando hayan varios faltantes consecutivos, no funciona, pues los capitulos se desfasan con respecto al indice, es decir: 1 - 1 2 - 2 3 - 4 4 - 5 5 - 8 6 - 9 Ahi me devuelve bien el 3, pero despues se desfasan y no puedo tomar como referencia el index. O quizas es que no entendi bien la idea |
Cita:
Una vez los tengas en la lista, recorre la lista de capítulos y almacena en otra (TStringList o TList<integer> aquellos que te faltan). Tal vez me estoy perdiendo algo, pero lo veo como un proceso sencillo. Tal vez algo de código ayude a entender lo que me estoy perdiendo... :o |
hola a todos!!
una alternativa puede ser utilizar las clases TArray<inteteger> o Tdictionary<integer, ....> en donde en este caso puede obtener un indice a los capitulos. Mira si estos códigos te pueden servir: Código:
/// ---- Código:
/// ----
|
Una manera simple es solo generar una lista de inicio..fin y marcar solo si encontró:
//pseudocodigo Código PHP:
|
Gracias a todos por sus respuestas
Probare los metodos de Bucanero a ver que tal resulta El metodo de mamcx, visto rapidamente, me parece que sucede lo mismo que con el metodo de escafandra |
Pues con el 2do metodo de bucanero (me gustó mas porque me recuerda a python), me funciono bastante bien
Lo que me queda es optimizar un poco el metodo de extraer el numero de capitulo, ya que cuando el capitulo esta delante no hay problema, pero cuando esta al final, se complica cuando el nombre de la novela contiene numeros. Por ejemplo: 1- Enemigo intimo 1 - 25 (1 es la temporada y 25 el capitulo) 2- 100 años de soledad - 11 (100 es parte del nombre y 11 el capitulo) Se me volvio un poco complicado ... |
La franja horaria es GMT +2. Ahora son las 21:18:00. |
Powered by vBulletin® Version 3.6.8
Copyright ©2000 - 2025, Jelsoft Enterprises Ltd.
Traducción al castellano por el equipo de moderadores del Club Delphi