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. 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. 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. 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. 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. 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. 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. 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. 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.
12. 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.
13. 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
14. 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
15.
16. 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.
17. 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.
19. 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.