Académique Documents
Professionnel Documents
Culture Documents
Algoritmo SinTitulo
acción 1;
acción 1;
acción n;
FinAlgoritmo
Comienza con la palabra clave Algoritmo(o alternativamente Proceso, son sinónimos) seguida del
nombre del programa, luego le sigue una secuencia de instrucciones y finaliza con la palabra
FinAlgoritmo(o FinProceso). Una secuencia de instrucciones es una lista de una o más instrucciones
y/o estructuras de control.
1. EJEMPLO:
Algoritmo Suma
// la instrucción Leer
Leer A
Leer B
C <- A+B
// finalmente, se muestra el resultado, precedido de un
// instrucción Escribir
FinAlgoritmo
Variables
En la mayoría de los lenguajes reales los nombres de variables no pueden contener acentos, ni
diéresis, ni eñes. En PSeInt, esto se permite, dependiendo del perfil de lenguaje seleccionado.
TIPOS DE DATOS
Numérico: números, tanto enteros como reales. Para separar decimales se utiliza el punto.
Ejemplos: 12 23 0 -2.3 3.14
Los tipos de datos simples se determinan automáticamente cuando se crean las variables. Las dos
acciones que pueden crear una variable son la lectura(LEER) y la asignación(<-). Por ejemplo, la
asignación "A<-0;" está indicando implícitamente que la variable A será una variable numérica. Una
vez determinado el tipo de dato, deberá permanecer constante durante toda la ejecución del
proceso; en caso contrario el proceso será interrumpido.
Opcionalemnte, se puede declarar una variable numérica como entera con la instrucción DEFINIR.
En este caso, todo valor no entero que se lea o asigne a la misma será truncado.
Arreglos
Los arreglos son estructuras de datos homogéneas (todos sus datos son del mismo tipo) que
permiten almacenar un determinado número de datos bajo un mismo identificador, para luego
referirse a los mismos utilizando uno o más subíndices. Los arreglos pueden pensarse como
vectores, matrices, etc. Para poder utilizar un arreglo, primero es obligatorio su dimensionamiento;
es decir, declarar los rangos de sus subíndices, lo cual determina cuantos elementos se almacenarán
y como se accederá a los mismos.
Dimensionamiento
Esta instrucción define un arreglo con el nombre indicado en <identificador> y N dimensiones. Los
N parámetros indican la cantidad de dimensiones y el valor máximo de cada una de ellas. La cantidad
de dimensiones puede ser una o más, y la máxima cantidad de elementos debe ser una expresión
numérica positiva.
Si se utilizan arreglos en base 0, al declarar un arreglo de, por ejemplo 15 elementos, los índices
de elementos válidos van de 0 a 14; mientras que si se utilizan arreglos en base 1 los índices válidos
van de 1 a 15. Esto se configura en el cuadro de Opciones del Pseudocódigo.
Se pueden declarar más de un arreglo en una misma instrucción, separándolos con una coma (,).
El ejemplo Mayores muestra cómo cargar datos en un arreglo y buscar luego el mayor entre dichos
datos.
El ejemplo Sucursales utiliza un arreglo bidimensional (matriz) para guardar las ventas de una
empresa discriminadas por producto (una de las dimensiones) y por sucursal (la dimensión
restante).
EXPRESIONES
Operadores
Este pseudolenguaje dispone de un conjunto básico de operadores que pueden ser utilizados para
la construcción de expresiones más o menos complejas.
Las siguientes tablas exhiben la totalidad de los operadores de este lenguaje reducido:
La jerarquía de los operadores matemáticos es igual a la del álgebra, aunque puede alterarse
mediante el uso de paréntesis. Para el caso de los operadores & y |, la evaluación se realiza en
cortocircuito. Esto significa que si dos expresiones están unidas por el operador ? y la primera se
evalúa como Falso, o están unidas por el operador | y la primera se evalúa como Verdadero, la
segunda no se evalúa ya que no altera el resultado.
Funciones
Notas:
El módulo (resto de la división entera) no se encuentra entre las funciones ya que fue implementado
como operador.
Las funciones trigonométricas reciben el ángulo en radianes. Para facilitar las conversiones se puede
usar la constante PI (Ej: si A es un ángulo en grados, su coseno se obtiene con "cos(A*PI/180)").
Las funciones que operan sobre cadenas de caracteres solo estarán disponibles si el perfil de
lenguaje seleccionado lo permite (ver Opciones del Pseudocódigo).
Para crear sus propias funciones en pseudocódigo para utilizar desde el procedimiento principal vea
la sección SubProcesos.
ACCIONES SECUENCIALES
Asignación
Lectura
Esta instrucción toma N valores desde el ambiente (en este caso el teclado) y los asigna a las N
variables mencionadas. Pueden incluirse una o más variables, por lo tanto el comando leerá uno o
más valores.
Escritura
Esta instrucción informa al ambiente (en este caso escribiendo en pantalla) los valores obtenidos
de evaluar N expresiones. Dado que puede incluir una o más expresiones, mostrará uno o más
valores. Si hay más de una expresión, se escriben una a continuación de la otra sin separación, por
lo que el algoritmo debe explicitar los espacios necesarios para diferenciar dos resultados si así lo
requiere.
Si en algún punto de la línea se encuentran las palabras clave "SIN SALTAR" o "SIN BAJAR" los valores
se muestran en la pantalla, pero no se avanza a la línea siguiente, de modo que la próxima acción
de lectura o escritura continuará en la misma linea. En caso contrario, se añade un salto de línea
luego de las expresiones mostradas.
La instrucción "Borrar Pantalla" (o "Limpiar Pantalla") permite, como su nombre lo indica, borrar
la pantalla y colocar el cursor en la esquina superior izquierda.
Borrar Pantalla;
La instrucción "Esperar Tecla" detiene su algoritmo hasta que el usuario presione una tecla
cualquiera de su teclado.
Esperar Tecla;
La instrucción "Esperar" también puede utilizarse para pausar el algoritmo durante un intervalo
de tiempo predefinido, indicando a continuación de la palabra clave la longitud y unidad de dicho
intervalo. Las unidades válidas son Segundos y Milisegundos.
Esperar 3 Segundos;
Estructuras de Control
Condicionales
Si-Entonces
Si <condición> Entonces
<instrucciones>
SiNo
<instrucciones>
FinSi
// calcula el area
Algoritmo TrianguloRectangulo
// cargar datos
Leer l1
Leer l2
Leer l3
Si l1>l2 Entonces
cat1<-l2
Si l1>l3 Entonces
hip<-l1
cat2<-l3
SiNo
hip<-l3
cat2<-l1
FinSi
SiNo
cat1<-l1
Si l2>l3 Entonces
hip<-l2
cat2<-l3
SiNo
hip<-l3
cat2<-l2
FinSi
FinSi
// calcualar area
area<-(cat1*cat2)/2
SiNo
FinSi
FinAlgoritmo
Selección Múltiple
La secuencia de instrucciones ejecutada por una instrucción Segun depende del valor de una
variable numérica.
<número1>: <instrucciones>
<número2>,<número3>: <instrucciones>
<...>
FinSegun
Esta instrucción permite ejecutar opcionalmente varias acciones posibles, dependiendo del valor
almacenado en una variable de tipo numérico. Al ejecutarse, se evalúa el contenido de la variable y
se ejecuta la secuencia de instrucciones asociada con dicho valor.
Cada opción está formada por uno o más números separados por comas, dos puntos y una
secuencia de instrucciones. Si una opción incluye varios números, la secuencia de instrucciones
asociada se debe ejecutar cuando el valor de la variable es uno de esos números.
Opcionalmente, se puede agregar una opción final, denominada De Otro Modo, cuya secuencia
de instrucciones asociada se ejecutará sólo si el valor almacenado en la variable no coincide con
ninguna de las opciones anteriores.
// Muestra como hacer un menú simple con las estructuras Repetir-Hasta Que y Según
Algoritmo sin_titulo
Repetir
// mostrar menu
Limpiar Pantalla
Leer OP
Segun OP Hacer
1:
2:
Escribir "Películas recomendables:"
3:
4:
5:
De otro modo:
FinSegun
Esperar Tecla
FinAlgoritmo
Estructuras de Control Repetitivas
Mientras
La instrucción Mientras ejecuta una secuencia de instrucciones mientras una condición sea
verdadera.
<instrucciones>
FinMientras
Note que las instrucciones del cuerpo del ciclo pueden no ejecutarse nunca, si al evaluar por
primera vez la condición resulta ser falsa.
Ejemplo
Algoritmo Adivina_Numero
intentos<-10
Leer num_ingresado
Si num_secreto>num_ingresado Entonces
SiNo
FinSi
Leer num_ingresado
FinMientras
Si num_secreto=num_ingresado Entonces
SiNo
FinSi
FinAlgoritmo
Repetir
La instrucción Repetir-Hasta Que ejecuta una secuencia de instrucciones hasta que la condición
sea verdadera.
Repetir
<instrucciones>
Al ejecutarse esta instrucción, la secuencia de instrucciones que forma el cuerpo del ciclo se
ejecuta una vez y luego se evalúa la condición. Si la condición es falsa, el cuerpo del ciclo se ejecuta
nuevamente y se vuelve a evaluar la condición. Esto se repite hasta que la condición sea verdadera.
Note que, dado que la condición se evalúa al final, las instrucciones del cuerpo del ciclo serán
ejecutadas al menos una vez.
Además, a fin de evitar ciclos infinitos, el cuerpo del ciclo debe contener alguna instrucción que
modifique la o las variables involucradas en la condición de modo que en algún momento la
condición sea verdadera y se finalice la ejecución del ciclo.
Si se utiliza sintaxis flexible (ver Opciones del Pseudocódigo) se permite opcionalmente utilizar:
de modo que el conjunto de acciones contenidas en el bucle se ejecuta mientras que la condición
sea verdadera. Notar que la palabra Que es la que diferencia el uso de la palabra Mientras en la
estructura repetir de la estructura Mientras. Es decir, si se omite la palabra que se considera como
el comienzo de un bucle Mientras en lugar de el final de un bucle Repetir.
El ejemplo Menú muestra un programa muy simple que utiliza esta estructura de control para
mostrar un menú repetidamente hasta que el usuario seleccione la opción para salir.
// Muestra como hacer un menú simple con las estructuras Repetir-Hasta Que y Según
Algoritmo sin_titulo
Repetir
// mostrar menu
Limpiar Pantalla
Leer OP
Segun OP Hacer
1:
2:
3:
4:
5:
De otro modo:
FinSegun
Esperar Tecla
FinAlgoritmo
Para
Para <variable> <- <inicial> Hasta <final> Con Paso <paso> Hacer
<instrucciones>
FinPara
Si se habilita la sintaxis flexible en la configuración del lenguaje se pueden utilizar dos alternativas.
La primera variante consiste en reemplazar el operador de asignación por la palabra clave Desde:
Para <variable> Desde <inicial> Hasta <final> Con Paso <paso> Hacer ...
De esta forma, la lectura de la sentencia resulta más obvia. Además, con sintaxis flexible, si no se
especifica el paso pero el valor final es menor al inicial, el bucle recorrerá los valores en orden
inverso como si el paso fuera -1. La segunda variante solo sirve para recorrer arreglos de una o más
dimensiones. Se introduce con la construcción Para Cada seguida de un identificador, la palabra
clave De y otro identificador:
El segundo identificador debe corresponder a un arreglo. El primero será el que irá variando en cada
iteración. El ciclo realizará tantas iteraciones como elementos contenga el arreglo y en cada uno el
primer identificador servirá para referirse al elemento del arreglo en cuestión.
El ejemplo Promedio utiliza un bucle de este tipo para leer N valores numéricos con los cuales
calcula un promedio.
Algoritmo Promedio
Leer n
acum<-0
Leer dato
acum<-acum+dato
FinPara
prom<-acum/n
FinAlgoritmo
Otro ejemplo con incremento
Algoritmo ValoresPares
Leer n
Escribir i
FinPara
FinAlgoritmo
El ejemplo Para utiliza las tres variantes de este tipo de bucles para recorrer un arreglo.
Algoritmo sin_titulo
Dimension A[10]
FinPara
FinPara
Escribir "" // deja una linea en blanco
// recorre los 10 elementos en orden inverso y los muestra en una misma linea
FinPara
FinAlgoritmo