clase 02
TRANSCRIPT
![Page 1: Clase 02](https://reader034.vdocuments.co/reader034/viewer/2022051314/559763bc1a28abf0778b484d/html5/thumbnails/1.jpg)
ALGORITMOS Y LENGUAJES
DE
PROGRAMACION
CAPITULO II
D I S E Ñ O D E A L G O R I T M O S
ESTRUCTURAS SECUENCIALES
SENTENCIAS SELECTIVAS
![Page 2: Clase 02](https://reader034.vdocuments.co/reader034/viewer/2022051314/559763bc1a28abf0778b484d/html5/thumbnails/2.jpg)
OBJETIVO
El objetivo principal de este
Capítulo es capacitar al estudiante
en los conceptos básicos de
algoritmos, que le permitan
obtener la destreza necesaria para
diseñar sus propios algoritmos.
DISEÑO DE ALGORITMOS
![Page 3: Clase 02](https://reader034.vdocuments.co/reader034/viewer/2022051314/559763bc1a28abf0778b484d/html5/thumbnails/3.jpg)
CONCEPTOS BASICOS DE ALGORITMO
Un algoritmo es todo proceso, rutina ó método para resolver un
problema; mediante una secuencia finita de acciones , cada cual
con un significado concreto y cuya ejecución genera un tiempo
finito.
La ventaja del algoritmo es que el programador se puede concentrar
en la lógica del problema y en las estructuras de control del
mismo. Dejando de lado las reglas de sintaxis del lenguaje de
programación.
Algoritmo, es sinónimo de procedimiento computacional y es
fundamental para la ciencia de la computación.
![Page 4: Clase 02](https://reader034.vdocuments.co/reader034/viewer/2022051314/559763bc1a28abf0778b484d/html5/thumbnails/4.jpg)
CONCEPTOS BASICOS DE ALGORITMO
PROPIEDADES:
• Finito
La ejecución de un algoritmo acaba en un tiempo finito; un procedimiento que falla en la
propiedad de la finitud es simplemente un procedimiento de cálculo.
• Preciso
Cada instrucción de un algoritmo debe ser precisa; debe tener en cuenta un rigor y no la
ambigüedad. Cada frase tiene un significado concreto.
• Posee entradas
La entrada se toma como un conjunto especifico de valores que inicializan el algoritmo.
• Posee salidas
Todo algoritmo posee una ó más salidas; la salida es la transformación de la entrada.
• Efectivo
Un algoritmo es efectivo cuando las operaciones se efectúan de un modo exacto y en
un tiempo finito aun usando métodos manuales.
![Page 5: Clase 02](https://reader034.vdocuments.co/reader034/viewer/2022051314/559763bc1a28abf0778b484d/html5/thumbnails/5.jpg)
CONCEPTOS BASICOS DE ALGORITMO
La solución de un problema exige el diseño de un
algoritmo que resuelva el problema propuesto.
SOLUCION DE UN PROBLEMA
PROBLEMA
PROGRAMA
DE
COMPUTADORA
CONSTRUCCION
DEL
ALGORITMO
![Page 6: Clase 02](https://reader034.vdocuments.co/reader034/viewer/2022051314/559763bc1a28abf0778b484d/html5/thumbnails/6.jpg)
DESCRIPCIÓN DE ALGORITMOS
Para describir un algoritmo se debe
utilizar algún método que permita
independizar dicho algoritmo del
lenguaje de programación.
• Diagramas de flujo
• PseudoCódico
![Page 7: Clase 02](https://reader034.vdocuments.co/reader034/viewer/2022051314/559763bc1a28abf0778b484d/html5/thumbnails/7.jpg)
DIAGRAMAS DE FLUJO
Es una representación detallada en
forma gráfica (mediante símbolos) de
los pasos que se realizan para la
solución de un problema unidos por
flechas, denominadas líneas de flujo,
que indican la secuencia de ejecución.
![Page 8: Clase 02](https://reader034.vdocuments.co/reader034/viewer/2022051314/559763bc1a28abf0778b484d/html5/thumbnails/8.jpg)
SIMBOLOS DE LOS DIAGRAMAS DE FLUJO
INICIO - FIN
Este símbolo indica el comienzo y el final de un ALGORITMO
ENTRADA-SALIDA
Este símbolo indica operaciones que tienen relación con los
dispositivos de entrada/salida.
PROCESO
Este símbolo se utiliza para indicar operaciones aritméticas.
DECISION
Este símbolo se utiliza para indicar en su interior comparaciones
de valores tales como: a = b
j < i
Estas comparaciones admiten dos salidas: verdad ó falso
![Page 9: Clase 02](https://reader034.vdocuments.co/reader034/viewer/2022051314/559763bc1a28abf0778b484d/html5/thumbnails/9.jpg)
SIMBOLOS DE LOS DIAGRAMAS DE FLUJO
Líneas de flujo
Este símbolo indica la dirección del
flujo que el programa debe seguir.
La secuencia normal de lectura de un
diagrama de flujo es de arriba hacia
abajo y de izquierda a derecha.
Conector dentro de página
Este símbolo indica la continuación de la
dirección del flujo dentro de la misma página.
![Page 10: Clase 02](https://reader034.vdocuments.co/reader034/viewer/2022051314/559763bc1a28abf0778b484d/html5/thumbnails/10.jpg)
SIMBOLOS DE LOS DIAGRAMAS DE FLUJO
Conector fuera de página
Este símbolo indica la continuación de la dirección
del flujo de una página a otra. Tiene la misma
misión que el anterior, pero este conector se utiliza
cuando las partes a enlazar se encuentran en
distinta página.
Ciclo repetitivoEste símbolo se utiliza para
indicar procesos repetitivos
![Page 11: Clase 02](https://reader034.vdocuments.co/reader034/viewer/2022051314/559763bc1a28abf0778b484d/html5/thumbnails/11.jpg)
PSEUDOCÓDIGO
Es la descripción de un algoritmo
mediante una secuencia lógica de
acciones, que en su conjunto forman la
solución del problema, utilizando
generalmente palabras reservadas para
representar las acciones.
![Page 12: Clase 02](https://reader034.vdocuments.co/reader034/viewer/2022051314/559763bc1a28abf0778b484d/html5/thumbnails/12.jpg)
PSEUDOCÓDIGO
Para desarrollar los pseudocódigos se utilizará el
Entorno de Desarrollo Integrado PseInt, que es un
lenguaje de programación imperativa simple y escrito
en castellano.
Es decir, PseInt es un editor e intérprete de programas
escritos en PseudoCódigo. Su interfaz gráfica permite
crear, almacenar, ejecutar y corregir fácilmente los
programas en PseudoCódigo.
![Page 13: Clase 02](https://reader034.vdocuments.co/reader034/viewer/2022051314/559763bc1a28abf0778b484d/html5/thumbnails/13.jpg)
PSEUDOCÓDIGO
La sencillez del lenguaje PseudoCódigo lo
hacen ideal para la enseñanza de la
programación.
Permitiendo el uso de valores numéricos,
números decimales, lógicos, caracteres y
arreglos.
Provee también funciones de entrada/salida y
Funciones matemáticas.
![Page 14: Clase 02](https://reader034.vdocuments.co/reader034/viewer/2022051314/559763bc1a28abf0778b484d/html5/thumbnails/14.jpg)
PSEUDOCÓDIGO
Estructura de un Algoritmo
Proceso <nombre>
<secuencia de instrucciones>
FinProceso
Cada instrucción termina en punto y coma.
<instrucción>; <instrucción>; ... <instrucción>;
![Page 15: Clase 02](https://reader034.vdocuments.co/reader034/viewer/2022051314/559763bc1a28abf0778b484d/html5/thumbnails/15.jpg)
Las palabras y símbolos que pertenecen al
pseudocódigo se escriben tal como deben
ir, por ejemplo:
Proceso; a diferencia de los nombres de
variables y otros símbolos y expresiones
que pueden variar.
PSEUDOCÓDIGO
![Page 16: Clase 02](https://reader034.vdocuments.co/reader034/viewer/2022051314/559763bc1a28abf0778b484d/html5/thumbnails/16.jpg)
PSEUDOCÓDIGO
Se pueden introducir comentarios luego de
una instrucción, o en líneas separadas,
mediante el uso de la doble barra ( // ).
Todo lo que precede a //, hasta el fin de la
línea, no será tomado en cuenta al
interpretar el algoritmo.
![Page 17: Clase 02](https://reader034.vdocuments.co/reader034/viewer/2022051314/559763bc1a28abf0778b484d/html5/thumbnails/17.jpg)
PSEUDOCÓDIGO
Identificadores
Los Identificadores son palabras
definidas por el programador para
identificar variables.
Identificador, o nombre de variable, debe
constar sólo de letras y
números, comenzando siempre por una
letra.
![Page 18: Clase 02](https://reader034.vdocuments.co/reader034/viewer/2022051314/559763bc1a28abf0778b484d/html5/thumbnails/18.jpg)
PSEUDOCÓDIGO
Tipo de Datos
a) Tipos Simples:
Numérica, números enteros y decimales,
se usa el punto para separar los
decimales.
Carácter caracteres o cadena de caracteres
se escribe entre comillas (“ “) ó („ „)
Lógicas toma dos valores: Verdadero ó Falso
b) Estructura de Datos: Arreglos
![Page 19: Clase 02](https://reader034.vdocuments.co/reader034/viewer/2022051314/559763bc1a28abf0778b484d/html5/thumbnails/19.jpg)
PSEUDOCÓDIGO
Palabras Reservadas
Las palabras reservadas no llevan acento.
Leer , Escribir , Dimension
Si-Entonces-Sino, Segun
Mientras Hacer, Repetir Hasta Que, Para
![Page 20: Clase 02](https://reader034.vdocuments.co/reader034/viewer/2022051314/559763bc1a28abf0778b484d/html5/thumbnails/20.jpg)
Estructuras Secuenciales
Las estructuras secuenciales están formadas por las
siguientes instrucciones:
Leer Entrada de datos
Escribir Salida de Resultados
Asignación Almacena un valor en una variable
PSEUDOCÓDIGO
![Page 21: Clase 02](https://reader034.vdocuments.co/reader034/viewer/2022051314/559763bc1a28abf0778b484d/html5/thumbnails/21.jpg)
Entrada de Datos
Definida por la Instrucción Leer que permite el
ingreso de datos al algoritmo desde el teclado.
Leer <variable1>,<variable2>,…., <variableN>;
Leer Numero;
Leer n1, n2, n3;
PSEUDOCÓDIGO
![Page 22: Clase 02](https://reader034.vdocuments.co/reader034/viewer/2022051314/559763bc1a28abf0778b484d/html5/thumbnails/22.jpg)
Salida de Resultados
Definida por la Instrucción Escribir y permite mostrar
resultados en la pantalla.
Escribir <expr1> , <expr2> , ... , <exprN> ;
Escribir "Ingrese el nombre:";
Escribir "Resultado:" , x*2 ;
PSEUDOCÓDIGO
![Page 23: Clase 02](https://reader034.vdocuments.co/reader034/viewer/2022051314/559763bc1a28abf0778b484d/html5/thumbnails/23.jpg)
Sentencia de Asignación
La Instrucción de Asignación permite almacenar
un valor en una variable.
<variable> <expresión> ;
PSEUDOCÓDIGO
![Page 24: Clase 02](https://reader034.vdocuments.co/reader034/viewer/2022051314/559763bc1a28abf0778b484d/html5/thumbnails/24.jpg)
PSEUDOCÓDIGO
Expresiones
Las expresiones son combinaciones (asociaciones) de
datos con operadores.
a 3
b 5 a + b – 7
Cada expresión toma un valor que se determina al
evaluar la expresión.
![Page 25: Clase 02](https://reader034.vdocuments.co/reader034/viewer/2022051314/559763bc1a28abf0778b484d/html5/thumbnails/25.jpg)
PSEUDOCÓDIGO
Expresiones
De acuerdo a los tipos de datos que se manipulan en
las expresiones pueden ser:
Expresiones aritméticas (devuelve un número)
Expresiones lógicas (devuelve un valor lógico)
Expresiones de carácter (devuelve un carácter)
.
suma a + b – 3 (expresión aritmética)
![Page 26: Clase 02](https://reader034.vdocuments.co/reader034/viewer/2022051314/559763bc1a28abf0778b484d/html5/thumbnails/26.jpg)
Para ejecutarse la asignación, primero se
evalúa la expresión de la derecha y luego se
asigna el resultado a la variable de la izquierda.
El tipo de la variable y el de la expresión deben
coincidir.
n 1; // asigna el número 1 a n
suma suma + 1; // incrementa el valor desuma en 1
PSEUDOCÓDIGO
![Page 27: Clase 02](https://reader034.vdocuments.co/reader034/viewer/2022051314/559763bc1a28abf0778b484d/html5/thumbnails/27.jpg)
PSEUDOCÓDIGO
Sentencia de Asignación
Ejemplo de sentencia de asignación:
a 5
suma ( 2 + 3 ) * X + T + Z
La jerarquía de los operadores matemáticos es igual
a la del algebra, aunque puede alterarse con el uso
de paréntesis.
![Page 28: Clase 02](https://reader034.vdocuments.co/reader034/viewer/2022051314/559763bc1a28abf0778b484d/html5/thumbnails/28.jpg)
PSEUDOCÓDIGO
Como ejemplos de sentencias de asignación podemos
mencionar:
Velocidad (distancia/(minuto*60+segundo+c/100))
Numero u + 100 + d+10 + c
AT (s+(s-1) + (s-2) + (s-3))^2
Sentencia de Asignación
![Page 29: Clase 02](https://reader034.vdocuments.co/reader034/viewer/2022051314/559763bc1a28abf0778b484d/html5/thumbnails/29.jpg)
PSEUDOCÓDIGO
Tipos de Operadores
Un operador indica el tipo de operación a realizar
sobre los datos.
Los operadores se clasifican en:
Operadores Aritméticos
Operadores relacionales
Operadores lógicos.
![Page 30: Clase 02](https://reader034.vdocuments.co/reader034/viewer/2022051314/559763bc1a28abf0778b484d/html5/thumbnails/30.jpg)
PSEUDOCÓDIGO
En las expresiones aritméticas se utilizan lossiguientes operadores aritméticos:
Expresiones Aritméticas
Operador Acción Ejemplo Resultado
- Resta 5 – 2 3
+ Suma 2 + 3 5
* Multiplicación 4 * 5 20
/ División 9 / 3 3
^ Potencia 5 ^ 2 25
![Page 31: Clase 02](https://reader034.vdocuments.co/reader034/viewer/2022051314/559763bc1a28abf0778b484d/html5/thumbnails/31.jpg)
Los operadores aritméticos nos permiten, básicamente,
hacer cualquier operación aritmética (suma, resta,
multiplicación y división)
- 3 * 6/3 resultado - 6
- 3 * (6/2) resultado - 9
PSEUDOCÓDIGO
Expresiones Aritméticas
![Page 32: Clase 02](https://reader034.vdocuments.co/reader034/viewer/2022051314/559763bc1a28abf0778b484d/html5/thumbnails/32.jpg)
Las expresiones lógicas son asociaciones de datos con
operadores relacionales y de su evaluación siempre se
obtiene un valor de tipo lógico (verdadero o falso).
PSEUDOCÓDIGO
Expresiones Lógicas
> Mayor que 5 > 3
>= Mayor o igual que a >= b
< Menor que 2 < 4
<= Menor o igual que a <= b
= Igual que m = n
<> Distinto que 3 <>2
Operador Relacional Acción Ejemplo
![Page 33: Clase 02](https://reader034.vdocuments.co/reader034/viewer/2022051314/559763bc1a28abf0778b484d/html5/thumbnails/33.jpg)
El operador conjunción (y) y el operador disyunción (o)
siempre actúan sobre dos operandos, mientras que, el
operador negación (no) sólo actúa sobre un operando.
PSEUDOCÓDIGO
Expresiones Lógicas
Operadores
Lógicos Acción Ejemplo
& Conjunción ( y ) (5>3) & (5=1) // falso
| Disyunción ( 0 ) (7=7) | (4>9) // verdadero.
NO Negación (no) NO (4=4) // falso
![Page 34: Clase 02](https://reader034.vdocuments.co/reader034/viewer/2022051314/559763bc1a28abf0778b484d/html5/thumbnails/34.jpg)
Los operadores lógicos producen un resultado booleano, y
sus operandos son también valores lógicos.
PSEUDOCÓDIGO
Expresiones Lógicas
Operadores Lógicos Acción Ejemplo
Y Conjunción (5>2) Y (4>1)
O Disyunción (2=2) O (a=b)
NO Negación No (9>3)
![Page 35: Clase 02](https://reader034.vdocuments.co/reader034/viewer/2022051314/559763bc1a28abf0778b484d/html5/thumbnails/35.jpg)
PSEUDOCÓDIGO
Expresiones Lógicas
Tabla de verdad del operador Y:
![Page 36: Clase 02](https://reader034.vdocuments.co/reader034/viewer/2022051314/559763bc1a28abf0778b484d/html5/thumbnails/36.jpg)
PSEUDOCÓDIGO
Expresiones Lógicas
Tabla de verdad del operador O:
![Page 37: Clase 02](https://reader034.vdocuments.co/reader034/viewer/2022051314/559763bc1a28abf0778b484d/html5/thumbnails/37.jpg)
PSEUDOCÓDIGO
Expresiones Lógicas
Tabla de verdad del operador negación (no):
Evaluar :
no ( 9 > 5 ) se obtiene como resultado falso
![Page 38: Clase 02](https://reader034.vdocuments.co/reader034/viewer/2022051314/559763bc1a28abf0778b484d/html5/thumbnails/38.jpg)
PSEUDOCÓDIGO
Prioridad de los operadores
Prioridad de los Operador, aritméticos, relacionales y lógicos
( ) Paréntesis.
^ Potencia
* , / , NO Multiplicación, división y negación.
+ , - , Y Signo más, signo menos y conjunción
>, <, >=, <=, <>, = , O Mayor que, menor que, mayor igual que,
menor igual que, igual que, distinto que y
disyunción
![Page 39: Clase 02](https://reader034.vdocuments.co/reader034/viewer/2022051314/559763bc1a28abf0778b484d/html5/thumbnails/39.jpg)
Funciones Matemáticas
FUNCIÓN SIGNIFICADO
RC(X) Raíz Cuadrada de X
ABS(X) Valor Absoluto de X
LN(X) Logaritmo Natural de X
EXP(X) Función Exponencial de X
SEN(X) Seno de X
COS(X) Coseno de X
ATAN(X) Arcotangente de X
TRUNC(X) Parte entera de X
REDON(X) Entero más cercano a X
La función raíz cuadrada no debe recibir un argumento
negativo. La función exponencial no debe recibir un
argumento menor o igual a cero.
![Page 40: Clase 02](https://reader034.vdocuments.co/reader034/viewer/2022051314/559763bc1a28abf0778b484d/html5/thumbnails/40.jpg)
CONSTRUCCION DE ALGORITMOS
Proceso Problema1
Leer a , b;
Escribir "a = ", a;
Escribir "b = ", b;
suma <- a + b;
resta <- a -b;
multiplica <- a*b;
dividir <- a/b;
Escribir "suma = " , suma;
Escribir "resta = " , resta;
Escribir "multiplica = ", multiplica;
Escribir "dividir = ", dividir;
FinProceso
PROBLEMA N° 1
Imprimir la suma, la resta y el producto de dos números.
![Page 41: Clase 02](https://reader034.vdocuments.co/reader034/viewer/2022051314/559763bc1a28abf0778b484d/html5/thumbnails/41.jpg)
CONSTRUCCION DE ALGORITMOS
PROBLEMA N° 2
Leer el radio de un circulo y calcular e imprimir su superficie y la
longitud de la circunferencia.
Proceso Problema2
pi<-3.1416;
Leer radio;
Superficie <- pi * radio^2 ;
Circunferencia <- 2 * pi * radio;
Escribir "Radio", radio;
Escribir "Superficie", superficie;
Escribir "Circunferencia", circunferencia;
FinProceso
![Page 42: Clase 02](https://reader034.vdocuments.co/reader034/viewer/2022051314/559763bc1a28abf0778b484d/html5/thumbnails/42.jpg)
PSEUDOCÓDIGO
PROBLEMA N°3 2
Calcular las raíces reales de una ecuación cuadrática ax + bx + c = 0
Proceso problema3
Escribir "introdusca las variables a, b y c";
Leer a, b, c;
x1<-(-b+RC((b^2)-(4*a*c))/(2*a));
x2<-(-b-RC((b^2)-(4*a*c))/(2*a));
Escribir "las raices son: ", x1, x2;
FinProceso
![Page 43: Clase 02](https://reader034.vdocuments.co/reader034/viewer/2022051314/559763bc1a28abf0778b484d/html5/thumbnails/43.jpg)
Estructuras no Secuenciales
SENTENCIAS SELECTIVAS:
Selección Simple Si-Entonces
Selección Doble Si-Entonces-Sino
Sentencia Múltiple Segun
SENTENCIAS REPETITIVAS:
Mientras Hacer
Repetir _ Hasta_Que
Para
PSEUDOCÓDIGO
![Page 44: Clase 02](https://reader034.vdocuments.co/reader034/viewer/2022051314/559763bc1a28abf0778b484d/html5/thumbnails/44.jpg)
Se utiliza cuando en el desarrollo de la solución de
un problema debemos tomar una decisión, para
seleccionar una alternativo a seguir.
La toma de decisión se basa en la evaluación de
una o más condiciones que nos permitan
seleccionar una alternativa de solución al problema
planteado.
PSEUDOCÓDIGO
Sentencias de Selección
![Page 45: Clase 02](https://reader034.vdocuments.co/reader034/viewer/2022051314/559763bc1a28abf0778b484d/html5/thumbnails/45.jpg)
PSEUDOCÓDIGO
a) SELECCION SIMPLE :
Si <condición> Entonces
Sentencia ejecutada si la condición es verdad
finSi
Si ( nota > = 10 ) Entonces
Escribir ( “ingreso”)
fin Si
Si-Entonces
Consiste en evaluar una condición; si el resultado de dicha evaluación es Verdad, se ejecuta la sentencia por verdad y termina la estructura.
![Page 46: Clase 02](https://reader034.vdocuments.co/reader034/viewer/2022051314/559763bc1a28abf0778b484d/html5/thumbnails/46.jpg)
INICIO Condición
n
FIN
V
F
La sentencia condicional o selectiva evalúa
una CONDICION (expresión lógica)
PSEUDOCÓDIGO
![Page 47: Clase 02](https://reader034.vdocuments.co/reader034/viewer/2022051314/559763bc1a28abf0778b484d/html5/thumbnails/47.jpg)
CONSTRUCCION DE ALGORITMOS
PROBLEMA N° 4
Escribir un algoritmo que lea los
datos: a , b y calcule e imprimir
la suma, la resta, la
multiplicación y la división de
ellos.
![Page 48: Clase 02](https://reader034.vdocuments.co/reader034/viewer/2022051314/559763bc1a28abf0778b484d/html5/thumbnails/48.jpg)
CONSTRUCCION DE ALGORITMOS
Proceso Problema4
Leer a, b;
suma<- a+b;
resta<- a-b;
multiplica <- a*b;
Si b>0 Entonces
division <- a/b;
FinSi
Escribir "suma = ", suma;
Escribir "resta = ", resta;
Escribir "multiplica = ", multiplica;
Escribir "division = ", division;
FinProceso
![Page 49: Clase 02](https://reader034.vdocuments.co/reader034/viewer/2022051314/559763bc1a28abf0778b484d/html5/thumbnails/49.jpg)
La sentencia de selección doble nos permite tomar
decisiones entre dos alternativas luego de evaluar una
condición (expresión lógica).
Si <condición>
Entonces
<instrucciones>
Sino
<instrucciones>
Finsi
PSEUDOCÓDIGO
b) SELECCION DOBLE : Si-Entonces-Sino
![Page 50: Clase 02](https://reader034.vdocuments.co/reader034/viewer/2022051314/559763bc1a28abf0778b484d/html5/thumbnails/50.jpg)
PSEUDOCÓDIGO
INICIO Condición
Sentencia
por VerdadV
Sentencia
por Falso
F
FIN
Si - Entonces - Sino
Si ( nota > = 10 )
Entonces
Escribir ( “ingreso”)
Sino
Escribir(“no-ingreso”)
Finsi
![Page 51: Clase 02](https://reader034.vdocuments.co/reader034/viewer/2022051314/559763bc1a28abf0778b484d/html5/thumbnails/51.jpg)
PSEUDOCÓDIGO
PROBLEMA N° 5
Escribir un algoritmo que lea tres números enteros positivos a, b y c
e imprima el mayor de ellos.
INICIO
Mayor aMayor b
a, b ,c
a, b, c
Mayor
FIN
a>bNO SI
c > Mayor Mayor csi
![Page 52: Clase 02](https://reader034.vdocuments.co/reader034/viewer/2022051314/559763bc1a28abf0778b484d/html5/thumbnails/52.jpg)
CONSTRUCCION DE ALGORITMOS
Proceso Problema5
Leer a, b, c;
Si a > b Entonces mayor <- a;
Sino mayor <- b;
FinSi
Si c > mayor Entonces mayor <- c;
Finsi
Escribir "a = ", a;
Escribir "b = ", b;
Escribir "c = ", c;
Escribir "mayor = ", mayor;
FinProceso
![Page 53: Clase 02](https://reader034.vdocuments.co/reader034/viewer/2022051314/559763bc1a28abf0778b484d/html5/thumbnails/53.jpg)
Es posible utilizar la sentencia Si para diseñar
estructuras de selección con más de dos alternativas.
Una estructura de selección de n
alternativas puede ser construida utilizando una estructura Si .
Las estructuras Si interiores a otras estructuras Si se
denominan anidadas o encajadas. Debe existir una correspondencia entre las palabras reservadas Si y
Finsi.
PSEUDOCÓDIGO
![Page 54: Clase 02](https://reader034.vdocuments.co/reader034/viewer/2022051314/559763bc1a28abf0778b484d/html5/thumbnails/54.jpg)
PSEUDOCÓDIGO
Sentencia de selección anidadas
Si (condición1) Entonces <instruccion1>
Sino
Si (condición2) Entonces <instrucción2>
Sino
Si (condición3) Entonces
<instruccion3>
Finsi
Finsi
Finsi
![Page 55: Clase 02](https://reader034.vdocuments.co/reader034/viewer/2022051314/559763bc1a28abf0778b484d/html5/thumbnails/55.jpg)
c) SENTENCIA DE SELECCIÓN MULTIPLE
La sentencia de selección múltiple, se usa para
seleccionar una de varias alternativas.
PSEUDOCÓDIGO
Sentencia 4
Sentencia 5
VALOR
DE
VARIABLE
Según sea
Sentencia 1
Sentencia 2
Sentencia 3
![Page 56: Clase 02](https://reader034.vdocuments.co/reader034/viewer/2022051314/559763bc1a28abf0778b484d/html5/thumbnails/56.jpg)
INICIO SELECTOR
sentencia 11
sentencia N
N
sentencia 2
C) SELECCION MULTIPLE
SENTENCIA Segun
2
ACCION Z
FIN
PSEUDOCÓDIGO
La selección Múltiple se utiliza
cuando existen más de dos alternativas
para la selección de una alternativa.
El selector puede ser una variable simple
o una expresión simple denominada
expresión de control.
![Page 57: Clase 02](https://reader034.vdocuments.co/reader034/viewer/2022051314/559763bc1a28abf0778b484d/html5/thumbnails/57.jpg)
C) SELECCION MULTIPLE : SENTENCIA Segun
PSEUDOCÓDIGO
Segun variable_numerica Hacer
opcion_1:
secuencia_de_acciones_1
opcion_2:
secuencia_de_acciones_2
opcion_3:
secuencia_de_acciones_3
De Otro Modo:
secuencia_de_acciones_dom
FinSegun
![Page 58: Clase 02](https://reader034.vdocuments.co/reader034/viewer/2022051314/559763bc1a28abf0778b484d/html5/thumbnails/58.jpg)
CONSTRUCCION DE ALGORITMOS
Proceso Problema6
leer n1, n2;
leer opcion;
segun opcion Hacer
1: suma <- n1 + n2;
Escribir "suma = ", suma;
2: resta <- n1 - n2;
Escribir "resta = ", resta;
3: multiplica <- n1*n2;
Escribir "multiplica = ", multiplica;
4: divide <- n1/n2;
Escribir "divide = ", divide;
5: potencia <- n1^n2;
Escribir "potencia = ", potencia;
De Otro Modo:
Escribir "Numero no Definido" ;
FinSegun
FinProceso
![Page 59: Clase 02](https://reader034.vdocuments.co/reader034/viewer/2022051314/559763bc1a28abf0778b484d/html5/thumbnails/59.jpg)
CONSTRUCCION DE ALGORITMOS
PROBLEMA Nº 7
Diseñar un algoritmo que lea un entero
positivo n y realice las siguientes cálculos:
Si N termina en 0 se cambia por el doble
Si N termina en 3 se cambia por la décima
parte
De otro modo matiene su valor inicial
![Page 60: Clase 02](https://reader034.vdocuments.co/reader034/viewer/2022051314/559763bc1a28abf0778b484d/html5/thumbnails/60.jpg)
CONSTRUCCION DE ALGORITMOS
Proceso Problema7
Leer n;
Segun n mod 10 Hacer
0: n <- n*2;
Escribir "Doble de N = ", n;
3: n <- n/10;
Escribir "Decima parte de N = ", n;
De Otro Modo:
n <- n;
Escribir "Numero N = ", n ;
FinSegun
FinProceso