Documenti di Didattica
Documenti di Professioni
Documenti di Cultura
Un algoritmo es una secuencia de pasos para resolver un problema. Los pasos deben estar muy bien definidos, y tienen que describir sin ambigedades cmo llegar desde el inicio hasta el final.
Componentes de un algoritmo
Conceptualmente, un algoritmo tiene tres componentes: 1. la entrada: son los datos sobre los que el algoritmo opera; 2. el proceso: son los pasos que hay que seguir, utilizando la entrada; 3. la salida: es el resultado que entrega el algoritmo. El proceso es una secuencia de sentencias, que debe ser realizada en orden. El proceso tambin puede tener ciclos (grupos de sentencias que son ejecutadas varias veces) y condicionales (grupos de sentencias que slo son ejecutadas bajo ciertas condiciones).
Lenguaje natural
Durante el proceso mental de disear un algoritmo, es comn pensar y describir los pasos en la misma manera en que hablamos a diario. Por ejemplo:
Teniendo los valores de a, b y c, calcular el discriminante D=b24ac. Si es discriminante es negativo, entonces la ecuacin no tiene soluciones reales. Si es discriminante es igual a cero, entonces la ecuacin tiene una nica solucin real, que es x=b/2a. Si el discriminante es positivo, entonces la ecuacin tiene dos soluciones reales, que son x1=(bD)/2a y x2=(b+D)/2a. Esta manera de expresar un algoritmo no es ideal, ya que el lenguaje natural es:
impreciso: puede tener ambigedades; no universal: personas distintas describirn el proceso de maneras distintas; y no estructurado: la descripcin no est expresada en funcin de componentes simples.
An as, es posible identificar los pasos del algoritmo. Por ejemplo, hay que evaluar la expresin b24ac, y ponerle el nombre D a su resultado. Esto se llama asignacin, y es un tipo de instruccin que aparece en casi todos los algoritmos. Despus de eso, el algoritmo puede usar el nombre D para referirse al valor calculado.
Diagrama de flujo
Un diagrama de flujo es una representacin grfica de un algoritmo. Los pasos son representados por varios tipos de bloques, y el flujo de ejecucin es indicado por flechas que conectan los bloques:
El inicio y el final del algoritmo son representados con bloques circulares. El algoritmo siempre debe ser capaz llegar desde uno hasta el otro, sin importar por qu camino lo hace. Un algoritmo no puede quedarse pegado en la mitad. La entrada y la salida de datos son representadas con romboides, que en la figura de arriba estn pintados de verde. Los diamantes representan condiciones en las que el algoritmo sigue uno de dos caminos. que estn etiquetados con s o no, dependiendo si la condicin es verdadera o falsa. Tambin puede haber ciclos, representados por flechas que regresan a bloques anteriores. En este ejemplo, no hay ciclos.
Otras sentencias van dentro de rectngulos, que en la figura estn pintados de azul. En este ejemplo, las sentencias son asignaciones, representadas en la forma nombre = valor. Los diagramas de flujo no son usados en la prctica para programar, pero son tiles para ilustrar cmo funcionan algoritmos sencillos.
Pseudocdigo
El pseudocdigo es una descripcin estructurada de un algoritmo basada en ciertas convenciones notacionales. Si bien es muy parecido al cdigo que finalmente se escribir en el computador, el pseudocdigo est pensado para ser ledo por humanos. Una manera de escribir el algoritmo para la ecuacin cuadrtica en pseudocdigo es la siguiente:
leer a leer b leer c discriminante = b - 4ac si discriminante < 0: escribir 'La ecuacin no tiene soluciones reales' o si no, si discriminante = 0: x = -b / 2a escribir 'La solucin nica es', x o si no: x1 = (-b x2 = (-b escribir escribir escribir - discriminante) / 2a + discriminante) / 2a 'Las dos soluciones reales son:' x1 x2
Las lneas que comienzan con leer y escribir denotan, respectivamente, la entrada y la salida del programa. Los diferentes casos son representados usando sentencias si y o si no. Las asignaciones siguen la misma notacin que en el caso de los diagramas de flujo. La notacin de pseudocdigo es bien liberal. Uno puede mezclar notacin de matemticas con frases en espaol, siempre que quede absolutamente claro para el lector qu representa cada una de las lneas del algoritmo.
Cdigo
El producto final de la programacin siempre debe ser cdigo que pueda ser ejecutado en el computador. Esto requiere describir los algoritmos en un lenguaje de programacin. Los lenguajes de programacin definen un conjunto limitado de conceptos bsicos, en funcin de los cuales uno puede expresar cualquier algoritmo. En esta asignatura, usaremos el lenguaje de programacin Python para escribir nuestros programas.
A partir de ahora, usted aprender a entender, escribir y ejecutar cdigos como ste.