Técnicas para La Formulación de Algoritmos
Técnicas para La Formulación de Algoritmos
Técnicas para La Formulación de Algoritmos
Diagrama de Flujo
Tanto en la fase de anlisis del problema como en el diseo de algoritmos, se plantea la necesidad de representar claramente el flujo de operaciones que se han de realizar para su resolucin y el orden en que estas operaciones deben ser ejecutadas. Para representar de una forma clara, concisa y esquemtica la secuencia de acciones que se han de realizar para resolver un problema, se pueden utilizar varias herramientas. Una de ellas es el llamado Diagrama de Flujo.
UN DIAGRAMA DE FLUJO ES LA REPRESENTACIN GRFICA DE UN ALGORITMO.
Tambin se puede decir que es la representacin detallada en forma grfica de como deben realizarse los pasos en la computadora para producir resultados. Se basa en la utilizacin de unos smbolos grficos que denominamos cajas, en las que escribimos las acciones que tiene que realizar el algoritmo. Las cajas estn conectadas entre s por lneas y eso nos indica el orden en el que tenemos que ejecutar las acciones. En todo algoritmo siempre habr una caja de inicio y otra de fin, para el principio y final del algoritmo. Los smbolos utilizados han sido normalizados por el instituto norteamericano de normalizacin (ANSI).
SMBOLO
DESCRIPCIN Indica el inicio y el final de nuestro diagrama de flujo. Indica la entrada y salida de datos. Dentro colocaremos las acciones de lectura y escritura. Smbolo de proceso y nos indica la asignacin de un valor en la memoria y/o la ejecucin de una operacin aritmtica. Smbolo de decisin indica la realizacin de una comparacin de valores. Se utiliza para representar los subprogramas. Conector dentro de pagina. Representa la continuidad del diagrama dentro de la misma pagina.
Curso: 1 5
E.E.T. N1
Conector fuera de pagina. Representa la continuidad del diagrama en otra pagina. Indica la salida de informacin por impresora.
Indica la salida de informacin en la pantalla o monitor. Lneas de flujo o direccin. Indican la secuencia en que se realizan las operaciones.
Ejemplo
Queremos hallar el producto de varios nmeros positivos introducidos por teclado y el proceso termina cuando se ingresamos un nmero negativo. 1. Inicializar la variable del producto. 2. Leer el primer nmero. 3. Preguntar si es negativo o positivo. 4. Si es negativo nos salimos y escribimos el producto. 5. Si es positivo, multiplicamos el nmero ledo y luego leemos un nuevo nmero, y se vuelve al paso 3.
Inicio
P1 Leer num
Num >= 0
Escribir P
Fin
Curso: 1 5
E.E.T. N1
Pseudo cdigo
Es un lenguaje de especificacin de algoritmos, pero muy parecido a cualquier lenguaje de programacin, por lo que luego su traduccin al lenguaje es muy sencillo, pero con la ventaja de que no se rige por las normas de un lenguaje en particular. Nos centramos ms en la lgica del problema. Mezcla de lenguaje de programacin y espaol (o ingles o cualquier otro idioma) que se emplea, dentro de la programacin estructurada, para realizar el diseo de un programa.
El pseudocdigo tambin va a utilizar una serie de palabras clave o palabras especiales que va indicando lo que significa el algoritmo. 1. Inicio y Fin: Por donde empieza y acaba el algoritmo. 2. S <cond> Entonces <acc1> If then else Sino <acc2> 3. Mientras <cond> /hacer while do 4. Repetir / hasta repeat until 5. Hacer /hasta for .. to 6. Segn sea Case
Algoritmo <nombre alg> Var <nombre>: <tipo> Inicio <Instrucciones> Fin Algoritmo Producto Var P, num: entero Inicio P1 Leer num Mientras num >=0 hacer P p*num Leer num Fin mientras Escribir p Fin
Curso: 1 5
E.E.T. N1
No hay una forma estndar de disear un pseudo cdigo, depende en gran medida del criterio del programador. A pesar de ello, es aconsejable, respetar lo ms rigurosamente posible las siguientes normas de carcter general: g Todo pseudo cdigo comienza con la palabra inicio y termina con la palabra fin. g Cada instruccin se debe escribir en una sola lnea. g Para su descripcin, se utilizan una serie de palabras reservadas, que inicialmente se escriban en ingls, como: start,; end; if; then; else; do; while; etc. En la actualidad estas palabras se utilizan en el idioma del pas respectivo, en nuestro caso el espaol, as estas palabras seran: inicio; fin; si; entonces; sino; hacer; mientras, etc. g Debe escribirse intentando mostrar claramente las dependencias de control dentro de los mdulos. g Cada estructura utilizada tendr un solo punto de comienzo y un solo punto de fin de estructura.
Estructuras Algortmicas
Las estructuras de operacin de programas son un grupo de formas de trabajo, que permiten, mediante la manipulacin de variables, realizar ciertos procesos especficos que nos lleven a la solucin de problemas. Estas estructuras se clasifican de acuerdo con su complejidad en:
Secuenciales
Cclicas
Estructuras Secuenciales
La estructura secuencial es aquella en la que una accin (instruccin) sigue a otra en secuencia. Las tareas se suceden de tal modo que la salida de una es la entrada de la siguiente y as sucesivamente hasta el fin del proceso. Una estructura secuencial se representa de la siguiente forma:
Inicio
Accin 1 Accin 2
Accin N
Fin
Curso: 1 5 E.E.T. N1
- Asignacin: La asignacin consiste, en el paso de valores o resultados a una zona de la memoria. Dicha zona ser reconocida con el nombre de la variable que recibe el valor. La asignacin se puede clasificar de la siguiente forma: Simples: Consiste en pasar un valor constate a una variable (a=15) Contador: Consiste en usarla como un verificador del numero de veces que se realiza un proceso (a=a+1) Acumulador: Consiste en usarla como un sumador en un proceso (a=a+b) De trabajo: Donde puede recibir el resultado de una operacin matemtica que involucre muchas variables (a=c+b*2/4). - Lectura: La lectura consiste en recibir desde un dispositivo de entrada (p.ej. el teclado) un valor. Esta operacin se representa en un pseudocodigo como sigue: Leer a, b Donde a y b son las variables que recibirn los valores Escritura: Consiste en mandar por un dispositivo de salida (p.ej. monitor o impresora) un resultado o mensaje. Este proceso se representa en un pseudocodigo como sigue: Escribe El resultado es:, R Donde El resultado es: es un mensaje que se desea aparezca y R es una variable que contiene un valor.
Problemas Secuenciales
1) Suponga que un individuo desea invertir su capital en un banco y desea saber cuanto dinero ganara despus de un mes si el banco paga a razn de 2% mensual. Inicio Leer cap_inv gan = cap_inv * 0.02 Imprimir La ganancia es:, gan Fin 2) Un vendedor recibe un sueldo base mas un 10% extra por comisin de sus ventas, el vendedor desea saber cuanto dinero obtendr por concepto de comisiones por las tres ventas que realiza en el mes y el total que recibir en el mes tomando en cuenta su sueldo base y comisiones. Inicio Leer sb, v1, v2, v3 tot_vta = v1 + v2 + v3 com = tot_vta * 0.10 tpag = sb + com Imprimir El total de las comisiones en el mes es de:, com Imprimir El total que cobrar en el mes el de:, tpag Fin
Estructuras de Condicionales
Las estructuras condicionales comparan una variable contra otro(s) valor(es), para que en base al resultado de esta comparacin, se siga un curso de accin dentro del programa. Cabe mencionar que la
Curso: 1 5
E.E.T. N1
comparacin se puede hacer contra otra variable o contra una constante, segn se necesite. Existen dos tipos bsicos, las simples y las mltiples.
Simples: Las estructuras condicionales simples se les conoce como Tomas de decisin. Estas tomas de decisin tienen la siguiente forma:
condicin
Accin(es)
Dobles: Las estructuras condicionales dobles permiten elegir entre dos opciones o alternativas posibles en funcin del cumplimiento o no de una determinada condicin. Se representa de la siguiente forma:
condicin
Accin(es)
Accin(es)
Donde: Si Condicin entonces.. accin(es) si no Indica el comando de comparacin Indica la condicin a evaluar Precede a las acciones a realizar cuando se cumple la condicin Son las acciones a realizar cuando se cumple o no la condicin Precede a las acciones a realizar cuando no se cumple la condicin
Mltiples: Las estructuras de comparacin mltiples, son tomas de decisin especializadas que permiten comparar una variable contra distintos posibles resultados, ejecutando para cada caso una serie de instrucciones especificas. La forma comn es la siguiente:
Curso: 1 5
E.E.T. N1
falso
verdadero
falso
verdadero
falso
Forma General Segn Variable Hacer Op1: Accin(es) Op2: Accin(es) . . OpN: accin Sino: Accin(es) Fin-segn
condicin
Problemas Condicionales
1) Un hombre desea saber cuanto dinero se genera por concepto de intereses sobre la cantidad que tiene en inversin en el banco. l decidir reinvertir los intereses siempre y cuando estos excedan a $7000, y en ese caso desea saber cuanto dinero tendr finalmente en su cuenta. Inicio Leer p_int, cap int = cap * p_int si int > 7000 entonces capf = cap + int fin-si Imprimir El capital final sera:, capf fin 2) Determinar si un alumno aprueba a reprueba un curso, sabiendo que aprobara si su promedio de tres calificaciones es mayor o igual a 70; reprueba en caso contrario. Inicio Leer calif1, calif2, calif3 prom = (calif1 + calif2 + calif3)/3 Si prom >= 70 entonces Imprimir alumno aprobado si no Imprimir alumno reprobado Fin-si Fin
Estructuras Cclicas
Se llaman problemas repetitivos o cclicos a aquellos en cuya solucin es necesario utilizar un mismo conjunto de acciones que se puedan ejecutar una cantidad especifica de veces. Esta cantidad puede ser fija (previamente determinada por el programador) o puede ser variable (estar en funcin de algn dato dentro del programa).Los ciclos se clasifican en:
Curso: 1 5
E.E.T. N1
. Accin 1
Accin 2
Donde: Variable: Variable de control del ciclo V1 Lmite inferior V2 Lmite superior
Accin N
En este ciclo la variable de control toma el valor inicial del ciclo y el ciclo se repite hasta que la variable de control llegue al lmite superior. Para que esto suceda cada vez que se realiza un recorrido del cuerpo del bucle la variable de control es incrementada en 1 (este incremento depende del lenguaje para el cul est destinado el diagrama de flujo, hay lenguajes que permiten incorporar un valor de incremento distinto de la unidad)
Curso: 1 5
E.E.T. N1
Hacer para n = 1 a 10 Leer num Si num > 0 entonces Imprimir num fin-si Fin-para Fin.
Hacer-Mientras:
Esta es una estructura que repetir un proceso durante N veces, donde N puede ser fijo o variable. Para esto, la instruccin se vale de una condicin que es la que debe cumplirse para que se siga ejecutando. Cuando la condicin ya no se cumple, entonces ya no se ejecuta el proceso. La forma de esta estructura es la siguiente:
condici n falsa
Accin N
Repetir-Hasta:
Esta es una estructura similar en algunas caractersticas, a la anterior. Repite un proceso una cantidad de veces, pero a diferencia del Hacer-Mientras, el Repetir-Hasta lo hace hasta que la condicin se cumple y no mientras, como en el Hacer-Mientras. Por otra parte, esta estructura permite realizar el proceso cuando menos una vez, ya que la condicin se evala al final del proceso, mientras que en el Hacer-Mientras puede ser que nunca llegue a entrar si la condicin no se cumple desde un principio. La forma de esta estructura es la siguiente:
Accin 1
Accin N
condici n verdadera
Curso: 1 5
E.E.T. N1