Foros Club Delphi

Foros Club Delphi (https://www.clubdelphi.com/foros/index.php)
-   Varios (https://www.clubdelphi.com/foros/forumdisplay.php?f=11)
-   -   Dudas sobre estructura de datos (https://www.clubdelphi.com/foros/showthread.php?t=76452)

Anel Hernandez 02-11-2011 10:43:05

Dudas sobre estructura de datos
 
Hola,

Estoy leyendo un fichero texto y guardando determinado dato en una arreglo de dos dimensiones. La dificultad esta en que los datos en el fichero no estan organizados. Debo entonces revisar todo el arreglo para ver si el read coincide con determinada condicion en mi arreglo, luego leer la posicion del ultimo valor guardado y ubicar el nuevo dato luego.

Lo he hecho con un arreglo de 2 dimensiones, varias funciones y condiciones. Me pregunto:

existira alguna estructura de datos(lista, fila, pila, etc) que me permita simplificar este proceso? existen funciones predefinidas de Delphi para busquedas de datos en matrices y determinacion de la proxima posicion nula ó 0 donde ubicar un nuevo dato?

gracias

ecfisa 02-11-2011 11:36:21

Cita:

Empezado por Anel Hernandez (Mensaje 417356)
Estoy leyendo un fichero texto y guardando determinado dato en una arreglo de dos dimensiones. La dificultad esta en que los datos en el fichero no estan organizados. Debo entonces revisar todo el arreglo para ver si el read coincide con determinada condicion en mi arreglo, luego leer la posicion del ultimo valor guardado y ubicar el nuevo dato luego.
Lo he hecho con un arreglo de 2 dimensiones, varias funciones y condiciones. Me pregunto:

existira alguna estructura de datos(lista, fila, pila, etc) que me permita simplificar este proceso? existen funciones predefinidas de Delphi para busquedas de datos en matrices y determinacion de la proxima posicion nula ó 0 donde ubicar un nuevo dato?

Hola Anel.

El problema para contestar a esa pregunta es que no explicas detalladamente en que consiste el proceso ni cuál es la condición u órden con que deberán almacenarse los datos leídos en el arreglo. No creo que se pueda aconsejar que determinada herramienta te simplificará un proceso del que no se conocen esos aspectos.

Un saludo.

Anel Hernandez 02-11-2011 11:51:42

Hola,

pongo un ejemplo:

tengo datos de una escuela donde tengo el numero del aula y el nombre del estudiante. leo los datos de un fichero donde no aparecen esos datos y otros muchos mas. Me interesan solo algunas aulas, no todas y las especifico en mi arreglo. leo el fichero:
read(F,ss);

luego compruebo en un ciclo que el pos(Miarreglo[i,j],ss)<>0 para ver que el valor leido coincide con una de las aulas que me interesa. Luego paso a leer consecutivamente el dato del estudiante. asi hasta que termine el fichero.

lo que pasa que lo mismo puedo encontrar primero al aula 3, a la 5, luego a la 1, la 2, etc.

hasta ahora lo que hago es leer, comprobar que lo leido me interesa y luego buscar la primera posicion vacia para guardar el dato.

mas claro?

gracias mil

ecfisa 02-11-2011 13:07:55

Cita:

Empezado por Anel Hernandez (Mensaje 417358)
Hola,
pongo un ejemplo:

tengo datos de una escuela donde tengo el numero del aula y el nombre del estudiante. leo los datos de un fichero donde no aparecen esos datos y otros muchos mas. Me interesan solo algunas aulas, no todas y las especifico en mi arreglo. leo el fichero:
read(F,ss);

luego compruebo en un ciclo que el pos(Miarreglo[i,j],ss)<>0 para ver que el valor leido coincide con una de las aulas que me interesa. Luego paso a leer consecutivamente el dato del estudiante. asi hasta que termine el fichero.

lo que pasa que lo mismo puedo encontrar primero al aula 3, a la 5, luego a la 1, la 2, etc.

hasta ahora lo que hago es leer, comprobar que lo leido me interesa y luego buscar la primera posicion vacia para guardar el dato.

mas claro?

Si por favor.

Cuando te referis a que "los datos en el fichero no estan organizados", es a que los datos de la línea leída no tienen órden, ¿ O que las líneas no respetan órden numérico por aula ? (me hace dudar el uso de la función Pos)

Tampoco tengo claro el motivo de almacenar las aulas de interés en una matriz (Miarreglo[i,j]) para comprobar si el aula leida está entre ellas.

Un saludo.

fjcg02 02-11-2011 13:50:55

Carga el fichero en un stringlist, lo ordenas y lo manipulas a partir de ahí.

Si los campos no están ordenados, tendrías que cambiar el orden de los mismos para aprovecharte de las ventajas del stringlist.

pseudo código

Código Delphi [-]
function XX;
var Lineas: Tstrings;
begin
  Lineas:= TString.Create;
  Lineas.Loadfromfile('c:\fichero.txt'); -- cargas el fichero en el stringlist
  Lineas.Sort; -- ordenas 

  -- hacer lo que quieras

end;

Prueba y sigue preguntando.
Otra posibilidad es que si tienes los datos separados por algún carácter, puedas utilizar las funciones de Neftalí manejando datos con origen en ficheros de texto.
http://neftali.clubdelphi.com/?p=437

Saludos

mamcx 02-11-2011 16:39:21

Tienes control sobre esa estructura? Puedes cambiarla?

Muchas veces los programas se complican porque la estructura es complicada. Es mucho mas simple optimizar los datos, que los algoritmos.

Si no puedes cambiarla, haz de todas maneras la tarea de pensar como seria su representacion ideal. Entonces puedes armarla en memoria, y leer de alli (si no es un archivo muy grande, o sea, de mas de 1 GB)

Anel Hernandez 02-11-2011 17:03:10

Hola,

el fichero tiene lineas con el numero del aula y luego en las lineas siguientes algunos datos de los alumnos. Ej:

aula4
alumno4.2
alumno4.1
aula2
alumno2.3
alumno2.1
alumno2.4
aula5
alumno5.2
alumno5.1

y de nuevo pueden aparecer las mismas aulas con nuevos alumnos
aula4
alumno4.3

etc. compruebo con el pos porque no me interesan todas las aulas y la linea ademas del numero del aula puede tener mas informacion que por ahora no necesito.

almaceno en la matriz para tener en dos dimensiones, una las aulas y otra los alumnos.

mamcx,
los ficheros de texto no los puedo cambiar. son generados por otro programa. Yo solo puedo leerlo.

gracias

Anel Hernandez 02-11-2011 17:07:40

fjcg02,
no me sirve asi pues las lineas vienen agrupadas por bloques encabezados por una fila que es la que identifico con el pos. Si ordeno todas las lineas pierdo los bloques.

oscarac 02-11-2011 17:26:47

tienes algo de codigo?

Anel Hernandez 02-11-2011 18:07:48

AUn no, lo tengo en la mente, esto buscando la manera menos engorrosa de hacerlo.

gracias

fjcg02 02-11-2011 18:25:32

Cita:

Empezado por Anel Hernandez (Mensaje 417403)
fjcg02,
no me sirve asi pues las lineas vienen agrupadas por bloques encabezados por una fila que es la que identifico con el pos. Si ordeno todas las lineas pierdo los bloques.

Tienes razón...

Yo manipularía los datos para dejar la información así

aula4-alumno4.2
aula4-alumno4.1
aula2-alumno2.3
aula2-alumno2.1
aula2-alumno2.4
aula5-alumno5.2
aula5-alumno5.1
aula4- alumno4.3

y lo cargaría en un TStringList, lo grabaría a otro fichero, y utilizaría la técnica de Neftalí para cargar los datos en un dataset.
Al cargar los datos los prepararía para que queden maqueados y luego sea más fácil manipularlos.

Saludos

ElDioni 02-11-2011 18:38:58

Y no podrías subir el archivo txt para echarle un vistazo y poder ver la estructura, mas que nada para hacernos una mejor idea de como es y así poder darte una respuesta más acertada.

Saludos.

Enan0 02-11-2011 21:34:20

Tambien podrias utilizar una Lista doblemente enlazada (si es que todabia se usan jaja) y ahi podris ir ordenandolo Como quieras.

Otra Opcion

Manejar N StringList uno para Aula. y ahi cargar el alumo correspondiente. No seria muy Distinto al tema de la Lista y los regis.

si mal no recuerdo la declaracion seria algo asi (hace mucho que no lo utilizo)

Código Delphi [-]

Type
pAlumno:^TAlumno;
Talumno=record
  pAntAlumno: pAlumno;
  ID:Integer;
  Nombre:string;
  Apellido:String;
  pSigAlumno: pAlumno;
end;


tPunt=^Aulas;
Aulas=record
  pAnterior:TPunt;
  NroAula:Integer; 
  Alumno:TAlumno;
  pSiguiente:Tpun;
end;

Si te parece buena la idea. te comento como seria crear e insertar Los datos en la Lista.

Pero como te dije. con unos StringList tambien Podrias Ordenarlos, buscar y manipular la informacion.

saludos


La franja horaria es GMT +2. Ahora son las 20:36:44.

Powered by vBulletin® Version 3.6.8
Copyright ©2000 - 2024, Jelsoft Enterprises Ltd.
Traducción al castellano por el equipo de moderadores del Club Delphi