Ejercicio resuelto con tablas de decisión. Ejemplo construcción

Anuncio
aprenderaprogramar.com
Ejercicio resuelto con tablas de
decisión. Ejemplo construcción
diagrama de flujo. (CU00149A)
Sección: Cursos
Categoría: Curso Bases de la programación Nivel I
Fecha revisión: 2024
Autor: Mario R. Rancel
Resumen: Entrega nº 48 del Curso Bases de la programación Nivel I
24
© 2006-2024 aprenderaprogramar.com
Ejercicio resuelto con tablas de decisión. Ejemplo construcción diagrama de flujo.
Continuamos el ejercicio que veniamos viendo en la entrega anterior.
Construimos la tabla C1 – No.
TABLA C1 – No
4-6-7-12
5-11
10-14
15-16
C1
No
No
No
No
C2
No
Sí
⎯
⎯
C3
⎯
⎯
Sí
No
C4
Sí
Sí
No
No
Volvemos a aplicar los criterios para dividir.
C2: 2 indiferencias.
C3: 2 indiferencias.
C4: 0 indiferencias.
C4 divide a C1 – No. Gráficamente:
Sí
No
C1
Sí
C4
Construimos la tabla C1 – No – C4 – Sí.
TABLA C1 – No – C4 – Sí
4-6-712
© 2006-2024 aprenderaprogramar.com
5-11
C1
No
No
C2
No
Sí
C3
⎯
⎯
C4
Sí
Sí
No
Ejercicio resuelto con tablas de decisión. Ejemplo construcción diagrama de flujo.
La tabla presenta una única fila variante que es C2. Estamos en un punto casi terminal. C2 divide a C1 –
No – C4 – Sí y da lugar a dos acciones:
C1 – No – C4 – Sí – C2 – Sí = Acción D.
C1 – No – C4 – Sí – C2 – No = Acción E.
Sí
No
C1
Sí
Sí
C4
No
No
C2
Acción E
Acción D
Volvemos al punto más próximo que tenemos abierto, que es C1 – No – C4 – No
TABLA C1 – No – C4 - No
10-14
15-16
C1
No
No
C2
⎯
⎯
C3
Sí
No
C4
No
No
La tabla presenta una única fila variante que es C3. Estamos en un punto casi terminal. C3 divide a C1 –
No – C4 – No y da lugar a dos acciones.
C1 – No – C4 – No – C3 – Sí = Acción F.
C1 – No – C4 – No – C3 – No = Acción G.
© 2006-2024 aprenderaprogramar.com
Ejercicio resuelto con tablas de decisión. Ejemplo construcción diagrama de flujo.
Hemos concluido la segunda rama y vamos a dibujar el esquema de decisión completo.
Sí
No
C1
C2
C4
Sí
Sí
No
C4
C2
Sí
Acción A
No
No
Acción B
Acción C
C3
Sí
No
Acción D
Sí
Acción E
No
Acción G
Acción F
Ya tenemos configurada la estructura de decisión. Vemos que el número de “acciones” que aparecen
(en realidad conjunto de acciones para cada caso) es de 7, mientras que en la tabla de origen teníamos
6 casos. Si esto es así ha de existir una casilla de acción asociada al mismo caso que otra. Si analizamos
diagrama frente a tabla vemos que:
C1 – Sí – C2 – No – C4 – Sí = Acción B – Caso 4-6-7-12.
C1 – No – C4 – Sí – C2 – No = Acción E – Caso 4-6-7-12.
Finalmente construimos un esquema de decisión referenciado a la tabla de origen.
Sí
C2
C4
No
Sí
Acciones
1-2-3-8
No
C1
C4
C2
Sí
Acciones
4-6-7-12
No
Acciones
9-13
© 2006-2024 aprenderaprogramar.com
No
Sí
Sí
Acciones
5-11
No
Acciones
4-6-7-12
Sí
Acciones
10-14
C3
No
Acciones
15-16
Ejercicio resuelto con tablas de decisión. Ejemplo construcción diagrama de flujo.
Conviene verificar que no hay discordancias entre tabla y esquema para evitar errores. Con este
esquema construir pseudocódigo resultará sencillo:
[Pseudocódigo aprenderaprogramar.com]
Si C1 = “S” Entonces
Si C2 = “S” Entonces
Acciones 1-2-3-8
SiNo
Si C4 = “S” Entonces
Acciones 4-6-7-12
SiNo
Acciones 9-13
FinSi
FinSi
SiNo
Si C4 = “S” Entonces
Si C2 = “S” Entonces
Acciones 5-11
SiNo
Acciones 4-6-7-12
FinSi
SiNo
Si C3 = “S” Entonces
Acciones 10-14
SiNo
Acciones 15-16
FinSi
FinSi
FinSi
COMENTARIOS
La instrucción Según (Caso) Hacer puede resultar de interés en algunas circunstancias. Recordemos que
su sintaxis era Según [Expresión] Hacer, por lo que en principio no nos va a ser útil para evaluar
múltiples expresiones simultáneamente. De cualquier forma, recomendamos consultar las
especificaciones del lenguaje que se esté empleando para conocer a fondo sus posibilidades.
Los ejercicios correspondientes a transformación de tablas de decisión en pseudocódigo y diagramas de
flujo los veremos más adelante.
Próxima entrega: CU00150A
Acceso al curso completo en aprenderaprogramar.com -- > Cursos, o en la dirección siguiente:
http://www.aprenderaprogramar.com/index.php?option=com_content&view=category&id=28&Itemid=59
© 2006-2024 aprenderaprogramar.com
Descargar