Estructuras de control selectiva

2.253 visualizaciones

Publicado el

Descripción de las estructuras de control selectiva IF/ELSE y SWITCH/CASE con ejemplos prácticos.

Publicado en: Ingeniería
0 comentarios
0 recomendaciones
Estadísticas
Notas
  • Sé el primero en comentar

  • Sé el primero en recomendar esto

Sin descargas
Visualizaciones
Visualizaciones totales
2.253
En SlideShare
0
De insertados
0
Número de insertados
1.634
Acciones
Compartido
0
Descargas
34
Comentarios
0
Recomendaciones
0
Insertados 0
No insertados

No hay notas en la diapositiva.

Estructuras de control selectiva

  1. 1. ESTRUCTURAS DE CONTROL SELECTIVA IF/ELSE – SWITCH CASE Ing. César Augusto Gutiérrez R.
  2. 2. ESTRUCTURA GENERAL DE UN PROGRAMA algoritmo (nombre_algoritmo) variables: tipo_1: lista_variables_1 tipo_2: lista_variables_2 . . . tipo_N: lista_variables_N constantes: lista_identificadores = valor INICIO sentencia_1 sentencia_2 . . . sentencia_N FIN_INICIO fin(nombre_algoritmo) Estructura de un algorítmico cuantitativo en pseudocódigo.
  3. 3. TIPOS DE DATOS VARIABLES En Pseudocódigo En lenguaje Numérico enteras int, short, long Numérico reales float, double Alfanuméricas Char, string Lógicas Boolean variables: entero: num_estudiantes real: prom_grupo, estatura, peso entero: num_clases = 0 entero: num_x = -9, num_y, num_z entero: deudas = 400000 real: c = -9., d, e = 1.5e-15 real: f = 4.03e19, g =.03 alfanumerico: sexo = ‘F’ alfanumerico: grado = ‘A’, c = 64 alfanumerico: nom_real = “Ramon Valdez”; alfanumerico: nom_artistico = “Don Ramon”; alfanumerico: email; int num_estudiantes; float prom_grupo, estatura, peso; int num_clases = 0; int num_x = -9, num_y, num_z; unsigned deudas = 400000; float c = -9., d, e = 1.5e-15; double f = 4.03e19, g =.03; char sexo = ‘F’; String nom_real[20] = “Ramon Valdez”; String nom_artistico[] = “Don Ramon”; String email[50]; char grado = ‘A’;
  4. 4. ESTRUCTURAS BÁSICAS SI (expresión_logica) ENTONCES secuencia 1 | camino 1 SINO Secuencia 2 | camino 2 FIN_SI if (expresión_logica) { código_secuencia1; } else { código_secuencia2; } MIENTRAS(expresión_logica)HAGA secuencia FIN_MIENTRAS while (expresion_logica) { secuencia } PARA (VC = LI,LF,INC) HAGA secuencia FIN_PARA for(expre1;expre2;expre3) { secuencia; }
  5. 5. QUÉ PASA CON LAS CONSTANTES? algoritmo (nombre_algoritmo) variables: tipo_1: lista_variables_1 tipo_2: lista_variables_2 . . . tipo_N: lista_variables_N constantes: lista_identificadores = valor INICIO sentencia_1 sentencia_2 . . . sentencia_N FIN_INICIO fin(nombre_algoritmo) constantes: PI = 3.14 TAMAÑO = 46 IVA = 0.16 asterisco = ‘*’ mensaje = “que hay de nuevo viejo” Hemos visto las variables, ¿pero que pasa con las constantes?
  6. 6. ESTRUCTURAS DE DECISIÓN IF/ELSE Los condicionales son empleados para elegir entre diferentes alternativas de acción. En el caso del lenguaje la estructura empleada para el uso de condicionales es la estructura if, cuya sintaxis básica se muestra a continuación if (condicion) { instrucciones_caso_verdadero } else { instrucciones_caso_falso } SI (condicion) ENTONCES instrucciones_caso_verdadero SI_NO instrucciones_caso_falso FIN_INICIO
  7. 7. EJEMPLO 1 Realice un algoritmo que diga si una persona es mayor de edad o no. El usuario debe ingresar la edad por teclado.
  8. 8. EJEMPLO 2 A un trabajador se le aplica un aumento del 15% en su salario si este es menor de $400000 y 8% en caso contrario. Realice un programa que imprima el sueldo del trabajador
  9. 9. ALGUNAS ANOTACIONES SOBRE LA ESTRUCTURA IF El uso del else no es obligatorio: La parte que es ejecutada cuando la condición del if es falsa no es obligatoria. Su uso o no depende de lo que pida el problema. Ejemplo: Se tiene un parque de diversiones en el cual si se es niño se hace un descuento del 25% sobre el tiquete que vale $5000. Realice un algoritmo el cual calcule el precio a pagar para una persona cualquiera (sea niño o adulto).
  10. 10. ALGUNAS ANOTACIONES SOBRE LA ESTRUCTURA IF Casos anidados: Es posible que puedan anidarse condicionales, esto, debido a que la condición puede tomar más de dos valores. Ejemplo 3: Se tiene la siguiente tabla en la cual se muestra el equivalente entre números y letras para la calificación de notas en una guardería. Realizar un algoritmo que tomando como base dicha tabla y como entrada las notas, imprima la nota en letras correspondiente.
  11. 11. ESTRUCTURAS DE DECISIÓN MÚLTIPLE IF/ELSE IF/ELSE • Problemas de decisión con alternativas: Son aquellos problemas que contienen expresiones de decisión con mas de dos alternativas, el ejemplo anterior constituye uno de estos casos. • ¿Cómo se tratan los problemas de este tipo? Los problemas de este tipo pueden ser tratados usando estructuras if anidadas (tal y como se llevo a cabo en el ejemplo anterior). Sin embargo a mas alternativas mas anidamiento y por lo tanto la codificación se hace mas difícil.
  12. 12. if(condicion1) { instrucciones_condicion_1_verdadero } else if(condicion2){ instrucciones_condicion_2_verdadero } . . . else if(condicion_N) { instrucciones_condicion_N_verdadero } else { instrucciones_caso_falso } Afortunadamente los creadores de C tuvieron el problema anterior en cuenta y añadieron dentro de la estructura if un elemento adicional, el else if. Básicamente, el else if es un abreviado para la implementación de if anidados. Esto da lugar a una sintaxis mas general para condicionales, gracias al cual es posible la implementación de condiciones con más de dos alternativas. ESTRUCTURAS DE DECISIÓN MÚLTIPLE IF/ELSE IF/ELSE
  13. 13. Ejemplo 4: Se tiene la siguiente tabla en la cual se muestra el equivalente entre números y letras para la calificación de notas en una guardería. Realizar un algoritmo que tomando como base dicha tabla y como entrada las notas, imprima la nota en letras correspondiente. Resuelva el problema utilizando if- else if- else. ESTRUCTURAS DE DECISIÓN MÚLTIPLE IF/ELSE IF/ELSE
  14. 14. ESTRUCTURA SWITCH/CASE Existen problemas los cuales contienen una serie de decisiones en las que se necesita probar por separado una variable o expresión por cada uno de los valores enteros contantes que pueda tomar, efectuando diferentes acciones según el caso. Se ofrece la estructura switch de selección múltiple, encargada de manejar tal toma de decisiones. switch(selector) { case valor_1: instrucciones_1; break; case valor_2: instrucciones_2; break; . . . case valor_N: instrucciones_N; break; default: instrucciones_default; break; } • La variable usada como variable selector debe ser un tipo ordinal (expresión entera: short, char, int,…). • Cada etiqueta (valor_1, valor_2,…, valor_N) es un valor único, constante, y cada etiqueta debe tener un valor diferente de los otros. • La palabra clave break permite salir de inmediato de la estructura switch, provocando que el control del programa pase a la primera instrucción después de la estructura switch.
  15. 15. EJEMPLO ESTRUCTURA SWITCH/CASE Se tiene un restaurante en el cual se manejan una lista de platos tal y como lo muestra la siguiente tabla: Implementar un algoritmo que tome como entrada la opción y de devuelva como resultado a la salida el menú elegido.
  16. 16. ESTRUCTURA SWITCH/CASE
  17. 17. COMENTARIOS SOBRE LA ESTRUCTURA SWITCH/CASE • La sentencia break se utiliza porque, de otra manera, los case de una instrucción switch se ejecutarían juntos, de tal manera que, si no se indica break en ninguna parte de la estructura switch, cada vez que suceda una coincidencia en la estructura, se ejecutaran las instrucciones de los case restantes. • Etiqueta no usada: La omisión del espacio entre la palabra case y el valor entero que se esta probando (Por ejemplo poner case3 en vez de case 3) en una estructura switch puede provocar un error de lógica. • Agregar el caso default (aunque hay situaciones en las que a veces este no es necesario) en las instrucciones switch es buena practica de programación. Ya que al incluir el caso default se enfoca al programador en la necesidad de procesar condiciones excepcionales.

×