Está en la página 1de 3

Garca Prez Karla Lesly A1 No: 18

Licenciatura en Informtica Administrativa

Algoritmos computacionales
Video documental
Un algoritmo es una secuencia de pasos lgicos necesarios para llevar a cabo una tarea especfica, como la solucin de
un problema. Los algoritmos son independientes tanto del lenguaje de programacin en que se expresan como de la
computadora que los ejecuta. En cada problema el algoritmo se puede expresar en un lenguaje diferente de
programacin y ejecutarse en una computadora distinta; sin embargo el algoritmo ser siempre el mismo.
Por ejemplo en una analoga con la vida diaria, una receta de un plato de cocina se puede expresar en espaol, ingles o
francs, pero cualquiera que sea el lenguaje, los pasos para la elaboracin del plato se realizaran sin importar el
cocinero.
Los pasos a seguir en la solucin de una ecuacin de segundo grado.
Los pasos matemticos para la solucin de un nmero factorial.
Las instrucciones para la liquidacin de una nmina.
Las acciones que se deben seguir para la obtencin de una estadstica.
Para llegar a la realizacin de un programa es necesario el diseo previo de un algoritmo, de modo que sin algoritmo no
puede existir un programa.
1.2 Lenguajes de programacin (Lenguaje mquina, ensamblador y de alto nivel)
Al igual que los idiomas sirven de vehculo de comunicacin entre seres humanos, existen lenguajes que realizan la
comunicacin entre ellos y las computadoras. Estos lenguajes permiten expresar las instrucciones que el programador
desea que la computadora ejecute.
Los principales tipos de lenguajes utilizados en la actualidad son tres:
Lenguaje maquina
Lenguaje de bajo nivel (ensamblador)
Lenguajes de alto nivel
Lenguajes mquina
Se llama lenguaje mquina a las instrucciones que se dan directamente a la computadora, utilizando una serie de dgitos
binarios o bits, representados por los nmeros 0 y 1 que especifican una operacin. Aunque este lenguaje es el que
entiende la computadora, es muy difcil de manejar en la comunicacin humana. Las instrucciones en lenguaje maquina
dependen del hardware de la computadora y, por lo tanto, diferirn de una computadora a otra.
Lenguajes de bajo nivel (ensamblador)
Los lenguajes de bajo nivel son ms fciles de utilizar que los lenguajes mquina, pero, al igual que ellos,
dependen de la mquina en particular. El lenguaje de bajo nivel por excelencia es el ensamblador
(assembler lenguaje). Las instrucciones en lenguaje ensamblador son conocidas como mnemotcnicos.
Por ejemplo, mnemotcnicos tpicos de operaciones aritmticas son:
en ingles, ADD, SUB, DIV, etc. en espaol, SUM,RES,DIV, etc.
Una instruccin tpica de suma seria:
ADD M, N, P
Esta instruccin podra significar "sumar el nmero contenido en la posicin de memoria M al nmero almacenado en la
posicin de memoria N y situar el resultado en la posicin de memoria P". Evidentemente es mucho ms sencillo
recordar la instruccin anterior con un mnemotcnico que su equivalente en cdigo mquina.
0110 1001 1010 1011
Un programa escrito en lenguaje ensamblador no puede ser ejecutado directamente por la computadora (en esto se
diferencia esencialmente del lenguaje mquina) sino que requiere una fase de traduccin al lenguaje mquina.
El programa original escrito en lenguaje ensamblador se denomina programa fuente y el programa traducido en lenguaje
maquina se conoce como programa objeto, ya directamente entendible por la computadora.
Lenguajes de alto nivel
Los lenguajes de alto nivel son los mas utilizados por los programadores. Estn diseados para que las personas
escriban y entiendan los programas de un modo mucho ms fcil que los lenguajes mquina y ensambladores. Otra
razn es que un programa escrito en un lenguaje de alto nivel es independiente de la mquina; esto es, las instrucciones
del programa de la computadora no dependen del diseo del hardware o de una computadora en particular. En
consecuencia, los programas escritos en lenguajes de alto nivel son portables o transportables, lo que significa la
posibilidad de poder ser ejecutados con poca o ninguna modificacin en diferentes tipos de computadoras; al contrario
que los programas en lenguaje mquina o ensamblador que slo se pueden ejecutar en un determinado tipo de
computadora.

Los lenguajes de alto nivel presentan las siguientes ventajas:


Garca Prez Karla Lesly A1 No: 18
Licenciatura en Informtica Administrativa

El tiempo de formacin de los programadores es relativamente corto comparado con otros lenguajes.
La escritura de programas se basa en reglas sintcticas similares a los lenguajes humanos. Nombres de las
instrucciones tales como READ, WRITE, PRINT, OPEN, etc. Las modificaciones y puestas a punto de los programas son
ms fciles.
Reduccin del coste de los programas.
Transportabilidad.
Los inconvenientes se concretan en:
Incremento del tiempo de puesta a punto al necesitarse diferentes traducciones del programa fuente para conseguir el
programa definitivo.
No se aprovechan los recursos internos de la mquina que se explotan mucho mejor en lenguajes mquina y
ensambladores.
Aumento de la ocupacin de memoria.
El tiempo de ejecucin de los programas es mucho mayor.
Al igual que pasa con los lenguajes ensambladores, los programas fuente tienen que ser traducidos por programas
traductores, llamados compiladores e interpretes.
Los lenguajes de programacin de alto nivel existentes en la actualidad son muy numerosos, aunque la prctica
demuestra que su uso mayoritario se reduce a BASIC, COBOL, PASCAL, C, C++,... y en el campo de la primera
enseanza a LOGO, PILOT...
1.3 Traductores de lenguaje
Los traductores de lenguajes son programas que traducen a su vez los programas fuente escritos en lenguajes de alto
nivel a cdigo mquina.
Los traductores se dividen en:
Compiladores
Interpretes
Interpretes
Un interprete es un traductor que toma un programa fuente, lo traduce y a continuacin lo ejecuta (dicho programa por
medio de la computadora desarrolla una tarea especifica).
Un lenguaje que soporte un traductor de tipo intrprete se denomina lenguaje interpretado. BASIC es el modelo por
excelencia interpretado.
Los programas fuente en BASIC se escriben con ayuda de un programa denominado editor que suele venir incorporado
al programa intrprete.
Compiladores
Un compilador es un programa que traduce los programas fuente escritos en lenguajes de alto nivel a lenguaje mquina.
Los programas escritos en lenguajes de alto nivel (en el editor del lenguaje) se llaman programas fuente y el programa
traducido programa objeto o cdigo objeto. El compilador traduce (sentencia a sentencia) el programa fuente.
Lenguajes compiladores tpicos son: PASCAL, COBOL, C..
Fases de la compilacin
La compilacin es el proceso de la traduccin de programas fuente a programas objeto.
El programa objeto obtenido de la compilacin no ha sido traducido normalmente a cdigo mquina sino a ensamblador.
Para conseguir el programa mquina real se debe utilizar un programa llamado montador o enlazador (linker). El proceso
de montaje conduce a un programa en lenguaje mquina directamente ejecutable:
Por ejemplo, el proceso de ejecucin de un Programa en C++ tiene los siguientes pasos:
Escritura del programa fuente con un editor (programa que permite a una computadora actuar de modo similar a una
mquina de escribir electrnica) y guardarlo en un dispositivo de almacenamiento (un disco).

Introducir el programa fuente en memoria.

Compilar el programa con el compilador C++.

Verificar y corregir errores de compilacin (listado de errores).

Obtencin del programa objeto.

El montador obtiene el programa ejecutable.

Se ejecuta el programa y si no existen errores, se tendr la salida del mismo.


Garca Prez Karla Lesly A1 No: 18
Licenciatura en Informtica Administrativa

También podría gustarte