Ejercicio Examen Universiad

Iniciado por hervasiop12345, 26 Julio 2011, 12:48 PM

0 Miembros y 1 Visitante están viendo este tema.

hervasiop12345

Hola a todos. Estoy intentando resolver un ejercicio de  un examen de la universidad y me las estoy viendo  negras y encima es una asignatura de introducción. Primero definimos un tipo para representar las horas. Nos dice expresamente que son 4 dígitos:

hora=TIPO<h1,h2,m1,m2:entero>

Ahora un tipo para definir un horario que se compone de la hora de salida y llegada de un bus desde Murcia hasta Alicante. Conclusión:Una tabla bidimensional de dos columnas y como nos dice un máximo de 100 buses 100 filas:

horario=TIPO TABLA [1..100,1..2] de hora

Hasta ahí perfecto. Ahora hay que hacer un procedimiento/acción que reciba el horario y una hora deseada como parámetros de entrada y en un parámetro de salida almacene la hora de salida de Murcia del autobús que llegue a Alicante a la hora más próxima a la que le hemos pasado. No sé si es sencillo pero al tener el tipo definido con 4 dígitos y la tabla estar compuesta igual no consigo hacerlo funcionar bien.

Espero sus respuestas/ideas. Muchas gracias a todos

ukol

Vale una búsqueda lineal en la tabla, no entiendo bien los 4 digitos, por que 4 digitos y no 2 cifras?, en todo caso la comparación se hace como en cadena:

bool esFechaMayor(fecha1, fecha2) {
    si fecha1.h1 > fecha2.h1
        devuelve Verdadero
     sino si fecha1.h1 < fecha2.h1
        devuelve Falso
     sino //es que son iguales
         si fecha1.h2 > fecha2.h2
            devuelve Verdadero
         sino si fecha1.h2 < fecha2.h2
             devuelve Falso
         sino //es que son iguales
             si fecha1.m1 > fecha2.m1
                 ....etcetera
                //ultimo sino
              sino
                  devuelve Falso//son fechas iguales
}

Mientras te escribía ese rollo se me ocurre una forma más simple:

bool esFechaMayor(fecha1, fecha2) {
     f1 = (fecha1.h1*10+fecha1.h2)*60 + fecha1.m1*10 + fecha1.m2
     f2 = ...lo mismo con fecha2...
     devuelve f1 > f2
}


hervasiop12345

Mmm creo que no me he explicado bien. Mira el enunciado del link y verás como así lo entiendes. Gracias de todos modos
http://view.samurajdata.se/psview.php?id=f597e449&page=1&all=1

ukol

No entiendo que es lo que no sabes hacer, el tipo hora debería definirse con 2 numeros, uno para la hora otro para el minuto, para comparar se hace como te dije, horas con horas y minutos con minutos, o se pueden pasar mejor las horas a minutos y luego comparar. Para buscar en la tabla un bucle que recorra y en cuanto se pase para, entonces lo buscado esta en i-1

hervasiop12345

#4
Gracias tio. Me estaba liando yo con una cosa y por eso lo pensaba de otra forma pero ya lo he resuelto. Creo que seria así



calculabus:acción(dato entrada:horario,dato salida:hora;dato-resultado bus:hora)
 Léxico
 -------
   i,j:entero,
   tmin,emin:entero;
   
 Algoritmo
 -----------
  i:=1;
  j:=2;
  emin:=salida.h*60+salida.m;
  tmin:=-1;
  MIENTRAS (i <> nf+1) Y (emin > tmin) HACER
     tmin:=entrada[i][j].h*60+entrada[i][j].m;
      SI (tmin >= emin) Y (i=0) ENTONCES
          bus.h:=entrada[i][1].h;
          bus.m:=entrada[i][1].m

     SI_NO (SI tmin >= emin) Y (i>0) ENTONCES
          bus.h:=entrada[i-1][1].h;
          bus.m:=entrada[i-1][1].m

     FIN_SI
     i:=i+1;
  FIN_MIENTRAS
FIN.









Ragnarok

No olvidéis leer las normas generales, además de las específicas de cada tablón.sgae, ladrones