Documenti di Didattica
Documenti di Professioni
Documenti di Cultura
Para poder programar en cualquier lenguaje es necesario conocer los códigos mediante los cuales podamos expresar las
tareas que queremos realizar. El Turbo Pascal como lenguaje de programación posee su propio código con palabras de
uso exclusivo para ciertas funciones, a estas palabras se les llama palabras reservadas.
PALABRAS RESERVADAS EN PASCAL SON:
Ejemplo:
CONST pi = 3.1415926;
De esta forma, el identificador “pi” recibirá el valor de 3.1415926 y no será posible cambiarlo en el transcurso del
programa.
Es posible declarar varias constantes sucesivamente, puede ser una por renglón o varias en un solo renglón. Cuando se
hace esto, la palabra reservada CONST solo se pone una sola vez como cabecera y a continuación todas las constantes
por definir.
Ejemplo:
CONST
PI = 3.1415926;
Nombre = 'Juan Gutiérrez';
Unidad =1;
O
CONST PI = 3.1415926; Nombre = 'Juan Gutiérrez'; Unidad = 1;
Pero por cuestiones de legibilidad es preferible la primera opción.
La declaración de variables se lleva a cabo de la misma forma, solo que en lugar de la palabra CONST utilizamos la
palabra VAR seguida de un nombre de identificador, dos puntos ":" el tipo (una clase válida de datos) y punto y coma
";".
Ejemplo:
VAR
Numero: integer, Nombre:
string; Cod: char; Rut: string
[10];
TIPO DE DATOS
El manejo de la información en Turbo Pascal se realiza mediante diferentes clases de datos.
Tipo entero
En esta categoría pascal cuenta con 5 tipos diferentes, cada uno abarca un rango especifico de valores y utilizan una
diferente cantidad de memoria dependiendo de ese rango. Naturalmente el trabajar con rangos menores nos ofrece
2Ñinst El blog del Segundo Ñ – 2nninst.tk
una mayor velocidad y menor espacio de memoria, pero si se utilizan enteros largos se cuenta con mayor precisión. Los
tipos de enteros en pascal son los siguientes:
Tipo reales
Los números reales son aquellos que cuentan con una parte decimal. En pascal se cuenta con varios tipos de datos
reales, pero no se pueden utilizar, más que el tipo Real, en máquinas que no cuente con un coprocesador matemático.
Los tipos de datos reales son:
Tipo Valores que Acepta
Real 2,9-39 a 1,738
Single 1,5-45 a 3,438
Double 5-324 a 1,7308
Extend 1,9-4851 a 1,14932
Comp -9,2-18 a 9,218
Los números de datos reales deben llevar por fuerza al menos un dígito de cada lado del punto decimal así sea éste un
cero.
Como por ejemplo, el número 5 debe representarse como: 5.0, el .5 como 0.5, etc.
En este tipo de datos se utiliza la notación científica, que es igual a la de las calculadoras, el dígito que se encuentra a
continuación de la E representa la potencia a la que se elevará el número 10 para multiplicarlo por la cantidad a la
izquierda de dicha E:
3.0E5 = 3.0 * 10A5 = 3.0 * 100000 = 300000 1.5E-4
= 1.5 * 10A-4 = 1.5 * 0.0001 = 0.00015
Tipo carácter
Los caracteres son cada uno de los símbolos que forman el código ASCII, el tipo estándar de Pascal para estos datos es
CHAR. Los caracteres se especifican entre apostrofes: 'a', ‘B’, '2', etc.
Tipo cadena
Las cadenas son secuencias de caracteres o arreglos que tienen una longitud máxima de 255 caracteres. Se definen
entre apostrofes. El tipo de Pascal para las cadenas es STRING.
El tamaño por defecto para un tipo string es de 255 caracteres, pero es posible definir uno menor indicando el tamaño
entre paréntesis cuadrado.
COMENTARIOS
Es posible introducir comentarios en el programa que sirvan únicamente para mejorar la comprensión del código fuente.
Un comentario no es tomado en cuenta al momento de la compilación del programa y es importante al. momento de
crearlo, modificarlo o mantenerlo.
Existen dos formas de colocar comentarios: entre laves: {comentario} o entre paréntesis y asteriscos
(*comentario*). PROGRAMA PRINCIPAL
Después de haber realizado todas las declaraciones se puede iniciar con el programa principal. El programa principal se
inicia con la palabra reservada BEGIN y termina con la palabra END., esta última con un punto al final.
Cada línea de código, enunciado, sentencia o instrucción completa que se escriba deberá terminar con un punto y
coma";". ASIGNACIÓN O IGUALACIÓN
La operación de asignación es una de las más utilizada ya que nos permite darle un valor determinado a las variables
que declaramos en el programa o lo que es lo mismo, igualarla a algún valor determinado.
2Ñinst El blog del Segundo Ñ – 2nninst.tk
El símbolo utilizado para la asignación es los dos puntos seguidos por el signo igual ":=", a la izquierda de dicho símbolo
se coloca el identificador al que se le asignará el valor y a la derecha se colocará un identificador o algún valor directo
que se asignará.
Ejemplo:
Valor := 126; { Valor almacena 126 }
A := 3 * 2; {A guardará el valor de la multiplicación de 3 por 2 }
Código := 'C; { Código almacenará la letra C }
SALIDA Y ENTRADA DE DATOS A LA PANTALLA
Es indispensable para todo programa que cuente con la capacidad de manejar entradas y salidas de información, ya que
sin estas capacidades sería un programa inútil.
SALIDA DE DATOS
Las instrucciones que permiten mostrar datos en la pantalla de la computadora son: WRITE Y WRITELN.
La sintaxis de los procedimientos es la siguiente:
WRITE (identificadores);
WRITELN (identificadores);
Donde los identificadores son aquellos que contienen la información que se desea mandar a la pantalla Es posible
utilizar varios de ellos por cada instrucción WRITE O WRITELN, únicamente separados por comas ",".
Ejemplo:
WRITE (Nombre, Apellido?, ApellidoM);
Esta línea de código desplegará consecutivamente los contenidos de los identificadores Nombre, ApellidoP y ApellidoM.
En caso de que la variable Nombre almacenara el valor Ruth, y la variable ApellidoP Parada y ApellidoM Stierling el
resultado en pantalla seria:
Ruth Parada Stierling
Podemos obtener el mismo resultado si utilizamos la siguiente estructura:
WRITE (Nombre);
WRITE (ApelidoP);
WRITE (ApelidoM);
Si en lugar de utilizar la instrucción WRITE hacemos uso de WRITELN con la misma sintaxis del ejemplo anterior:
WRITELN (Nombre);
WRITELN(ApellidoP);
WRITELN(ApellidoM);
Lo que obtendríamos sería: Ruth
Parada
Stierling
De este ejemplo podemos concluir que la diferencia entre las instrucciones WRITE Y WRITELN es que la última imprime
el contenido de los identificadores y cambia el cursor al siguiente renglón de la pantalla, y la primera escribe el
contenido y deja el cursor al final del dato escrito.
En caso existir paréntesis en la expresión se evaluara primero el contenido de los paréntesis antes que otros
operadores.
Si existen dos operadores de igual prioridad se evaluará de izquierda a derecha.
Ejemplo de evaluación de los operadores:
PROGRAM Operadores;
VAR
Resultl, Result2: real; BEGIN
Resultl := 3 + 5 * 7;
Result2 := (3 + 5) * 7;
Writeln(‘El resultado de la operación 3 + 5 * 7 es:', Resultl);
Writeln('El resultado de la operación (3 + 5) * 7 es:',
Result2), END.
Como se podrá observar en la primera operación se ejecutará primero la operación 7 * 5 y al resultado se le sumarán 3,
en cambio, en la segunda operación se realizará primero la suma de 3 + 5 para multiplicarle al resultado 7.
OPERDORES RELACIONALES
Relacional Significado
= Igual a Lógico Significado
> Mayor que OR La expresión será cierta si cualquier operando es cierto
< Menor que AND La expresión será cierta si todos los operandos son ciertos
>= Mayor o igual que NOT Se utiliza como prefijo para negar un operando
<= Menor o igual que
BIFURCACIONES CONDICIONALES
Sentencia IF...THEN... ELSE
Esta expresión es utilizada para ejecutar una sentencia en el caso que una condición establecida sea verdadera, de lo
contrario se podrá ejecutar una sentencia distinta. Su sintaxis es:
IF condición THEN instrucción ELSE otro
Donde condición es la expresión que se evaluará, en caso de ser verdadera se ejecutará la sentencia dada como
instrucción, en caso de que la condición sea falsa se ejecutará la sentencia dada como otro.
Ejemplos:
1.- IF A>10 THEN
WRITELNCa mayor a 10);
2.- IF A>10 THEN
BEGIN
A := A * 8;
WRITELNCno mayor a 10');
WRITELNCpuede ser igual');
END;
3.- IF A>10 THEN
WRITELNCa mayor a 10);
2Ñinst El blog del Segundo Ñ – 2nninst.tk
ELSE
WRITELN('menor o igual a 10');
4.- IFA>10THEN
BEGIN
A := A * 8;
WRITELN('no mayor a 10');
WRITELN('nuevo valor', A);
END
ELSE
BEGIN
WRITELN('menor o igual a 10');
WRITELN(A);
END;
EJERCICIOS:
1. Leer dos números y determine cuál de ellos es menor o si son iguales
2. Leer tres números y determine cuál de ellos es menor. Supongamos que van a ser distintos.
3. Leer tres números y determinar cuál es el mayor teniendo en cuenta que se pueden dar igualdad entre ellos.
4. Leer un número y determinar si es mayor igual que 10 o no.
5. Leer un número y determinar si es positivo y par al mismo tiempo.
6. Leer un número y determinar si es divisible por 5.
7. Leer un número y determinar si este es positivo e impar.
8. Leer un número y determinar si este es mayor a 10 y menos a 86 y par al mismo tiempo.
9. Leer un número, si es positivo súmele 3, si es negativo súmele 6, luego indique si el resultado del calculo es positivo,
negativo o 0.
10. Leer un número y determinar si es divisible por 3 y por 2 al mismo tiempo.
11. Leer un número y determinar sí es divisible por 3 y por 2 al mismo tiempo pero sin usar conectores lógicos.
12. Lea un nombre y edad de 15 personas y muestre el nombre de la persona mayor.
13. Una empresa necesita contratar una secretaria. Para ello se le hacen las siguientes preguntas:
¿Es soltera (1) o casada (2)
¿Cuántos hijos tiene? Si no tiene indicar O
¿Tiene título técnico S/N?
¿Cuál es su edad?
Las postulantes debe cumplir los siguientes requisitos para ser preseleccionadas:
Las solteras deben poseer título técnico, no tener hijos y ser menor a 24 años. Las
casadas debe tener edad superior a 40 años y tener hijos.
El algoritmo que desarrolle debe permitir evaluar estas condiciones para determinar, mediante mensajes, si el
contrato se hace efectivo o no, por lo tanto, debe realizar los ingresos correspondientes y entregar el mensaje
respectivo.
No se sabe el numero de postulantes que se presentarán.
Ciclo WHILE
Los ciclos WHILE ofrecen la ventaja de que la ejecución se realiza mientras se cumpla una condición, por lo tanto es
posible controlar el número de repeticiones una vez iniciado el ciclo. Su sintaxis es:
WHILE condición DO instrucción
Donde condición es la condición que se evaluará, mientras ésta sea verdadera se ejecutará la instrucción, que es una o
varias sentencias
Ejemplo:
PROGRAM Ciclo_WHILE;
VAR
Num: integer;
BEGIN
2Ñinst El blog del Segundo Ñ – 2nninst.tk
Num := 1;
WHILE Num <= 50 DO
BEGIN
GOTOXY(10,5); WRITELN(Nuni);
Num := Num + 1;
END;
END.
Ejemplo:
PROGRAM CICLOREPEAT;
USES CRT;
VAR
NUMERO: INTEGER;
BEGIN
NUMERO:=1;
REPEAT
WRITELN(NUMERO);
NUMERO := NUMERO + 1;
UNTIL NUMERO = 50;
END.
Para trabajar con los elementos de un arreglo, se debe utilizar un índice, este puede ser un número o una variable
numérica entera.
Ejemplo:
matriz :array[1..5] of string[10]; edad:
array[1..5] of integer;
Ejemplos:
PROGRAM MATRICES; USES CRT;
VAR
MATRIZ : ARRAY[1..5] OF INTEGER;
Y: INTEGER;
BEGIN
(* INGRESO DE DATOS A UN ARREGLO *) FORY:=1
TO5DO
BEGIN
WRITELN(’INGRESE UN NUMERO’);
READLN(MATRIZ[Y])
END;
(* DESPLIEGA DATOS DE UN ARREGLO *)
FORY:=1 TO5DO
BEGIN
WRITELN(‘NUMERO ‘,MATRIZ[Y], ' POSICIÓN ', ,Y);
DELAY(500);
END;
END.
PROGRAM CARACTERES;
USES CRT;
VAR
MATRIZ : ARRAY[1..5] OF STRING[10];
X, Y: INTEGER;
BEGIN
FORY-1 TOS DO
BEGIN
CLRSCR;
GOTOXY(5,5);WRITELN('INGRESE UN NOMBRE’);
GOTOXY(25,5);READLN(MATRIZ[Y])
END;
FORY.=1 TOS DO
BEGIN
WRITELN('NOMBRE ',MATRIZrY], 'POSICIÓN ',Y);
DELAY(1500);
END;
END.
PROCEDIMIENTOS
Un procedimiento es una parte del programa (grupo de sentencias) que realiza una tarea específica En lugar de
reescribir el código completo de esa tarea cada vez que se necesite, únicamente se hace una referencia al nombre del
procedimiento.
Una vez creado un procedimiento actuará como una instrucción más de Pascal, y para ejecutarlo únicamente se dígita el
nombre de dicho procedimiento.
Para pode ejecutar un procedimiento es necesario declararlo en el programa que se este utilizando.
2Ñinst El blog del Segundo Ñ – 2nninst.tk
CREACIÓN DE PROCEDIMIENTOS
Se declaran después de haber declarado variables y constantes, antes del cuerpo del programa principal. La palabra
reservada para su declaración es Procedure seguida del nombre del procedimiento.
Sintaxis de un procedimiento:
Un procedimiento consta de :
Un encabezado de procedimiento
Una sección de declaraciones
Un cuerpo formado por:
la palabra reservada BEGIN
las sentencias del procedimiento
la palabra reservada END seguida de un punto y coma ( ; )
Ejemplo:
Procedure titulo;
Begin
Writeln(‘PROGRAMA DE PRUEBA');
End;
Uso de los procedimientos
Una vez declarado el procedimiento es posible utilizarlo como una instrucción de Pascal. Al uso del procedimiento se le
conoce como llamada al procedimiento.
El siguiente programa ilustra el uso o la llamada al procedimiento creado anteriormente:
PROGRAM PROCEO;
USES CRT;
PROCEDURE ÁSTER;
BEGIN
WRITELN(‘********************');
END;
PROCEDURE HOLA;
BEGIN
WRITELN('HOLAAAAAA');
END;
PROCEDURE CHAO;
BEGIN
WRITELN(‘CHAOOOOOOO');
END;
BEGIN
CLRSCR;
ÁSTER;
HOLA;
ÁSTER;
CHAO;
ÁSTER;
END.
En el se definen tres procedimientos: áster, hola y chao antes del cuerpo del programa, en el cuerpo del programa se
llaman a ejecución el cual al ejecutarse el programa desplegara:
HOLAAAAAA
********************
CHAOOOOOOO
********************