RPyAApunte - Java Manual PDF
RPyAApunte - Java Manual PDF
RPyAApunte - Java Manual PDF
RESOLUCION
DE PROBLEMAS Y
ALGORITMOS
Analista de Sistemas y
Licenciatura en Sistemas
Lic. Vernica L. Vanoli
Mg. Sandra I. Casas
Universidad Nacional de la Patagonia Austral
Unidad Acadmica Ro Gallegos
Carreras: Analista de Sistemas y Licenciatura en Sistemas
Asignatura: Resolucin de Problemas y Algoritmos
Docente: Lic. Vernica L. Vanoli
Indice
i
La Programacin 1
Anlisis del Problema 3
Ejemplos 4
Diseo del Algoritmo 4
Ejemplos 5
Escritura inicial del algoritmo 7
Datos 8
Tipos de Datos Simples 9
Tipos de Datos Compuestos o Clases/Objetos 9
Operaciones 9
Asignacin 9
Expresiones 10
Entrada 13
Salida 13
Ejemplos 14
Estructuras de Control 16
Secuenciacin 16
Ejemplos 16
Seleccin 17
Estructura SI-SINO 18
Ejemplos 18
Estructura ALTERNAR-CASO 21
Ejemplos 23
Iteracin 26
Estructura MIENTRAS 27
Bucles controlados por contador 28
Bucles controlados por sucesos 29
Bucles contadores 30
Bucles acumuladores/sumadores 30
Cmo disear bucles? 31
Ejemplos 35
Estructura HACER-MIENTRAS 37
Ejemplos 37
Estructura PARA 38
Ejemplos 39
Identacin 41
Llaves 42
Estructura General de un Programa 45
Estructura General de un Programa en Pseudocdigo 46
Ejemplos 46
Declaracin de constantes y variables 46
Uso de variables 48
Pruebas del programa 48
Arreglos 49
Arreglos Unidimensionales: Vectores 49
Declaracin y creacin 50
ndices 50
Manejo 51
Carreras: Analista de Sistemas y Licenciatura en Sistemas
Asignatura: Resolucin de Problemas y Algoritmos
Docente: Lic. Vernica L. Vanoli
Indice
ii
Ejemplos 52
Ordenacin y Bsqueda 55
Ordenacin por Insercin 55
Ordenacin por Seleccin 56
Ordenacin por Intercambio 58
Bsqueda Secuencial 59
Bsqueda Binaria 60
Arreglos Bidimensionales: Matrices 62
Declaracin y creacin 63
Manejo 63
Ejemplos 64
Diseo de Algoritmos: Funciones 68
Funciones 70
Ejemplos 71
Aserciones: Precondiciones y Postcondiciones 75
Invocacin a la funcin 75
Conceptos fundamentales de una funcin 78
Variables locales 79
Parmetros 79
Visibilidad de identificadores 83
mbito de identificadores 84
Clases/Objetos: Tipos de Datos Compuestos 85
Orientacin a Objetos 85
Objetos 87
Clases 90
Mensajes 93
Constructor 93
Clase Vector 98
Ejemplos 101
Clase Matriz 103
Ejemplos 105
Lenguaje de Programacin: JAVA 108
De Pseudocdigo a Java 112
Estructuras de Control en Java 115
Clases en Java 119
El mtodo main 122
Referencias en Java 123
Agregacin y Dependencia 126
Parmetros 127
Paquetes 128
Modificadores de acceso 128
Sobrecarga 131
Operador THIS 132
Arreglos en Java 132
Programas en Java 135
API 135
Clase String (Cadena) 136
Clases estticas 138
Carreras: Analista de Sistemas y Licenciatura en Sistemas
Asignatura: Resolucin de Problemas y Algoritmos
Docente: Lic. Vernica L. Vanoli
Indice
iii
La clase Random 146
Pilas 148
Implementacin 149
Colas 153
Implementacin 154
Recursividad 157
Ejemplos 161
ANEXO: Los Lenguajes de Programacin 163
Bibliografa 165
Carreras: Analista de Sistemas y Licenciatura en Sistemas
Asignatura: Resolucin de Problemas y Algoritmos
Docente: Lic. Vernica L. Vanoli
Apunte de Ctedra
- Pgina 1 de 165 -
Una computadora es un dispositivo electrnico utilizado para procesar informacin y obtener
resultados. Los datos y la informacin se pueden introducir en la computadora como entrada (input) y
a continuacin se procesan para producir una salida (output, resultados).
COMPUTADORA
Programa
Datos
de
entrada
Datos
de
salida
Los componentes fsicos que constituyen la computadora, junto con los dispositivos que realizan las
tareas de entrada y salida, se conocen con el trmino Hardware. El conjunto de instrucciones que
hacen funcionar a la computadora se denomina programa; a la persona que escribe programas se
llama programador y al conjunto de programas escritos para una computadora se llama Software.
LA PROGRAMACION
Muchas de las cosas que realizamos diariamente las hacemos en forma automtica o inconsciente, sin
pensar o analizar cada vez que las realizamos, como las hacemos. Por ejemplo, no es necesario pensar
las cosas que hacemos para avanzar la pgina de un libro:
1. levantar la mano;
2. mover la mano a la parte derecha del libro;
3. agarrar la esquina de la pgina;
4. mover la mano de derecha a izquierda hasta que la pgina se posicione, de forma que pueda leerse
lo que hay en la otra cara;
5. soltar la pgina.
Porque ya hemos aprendido a realizar esta tarea.
Otro ejemplo sera el conjunto de acciones que realizamos cuando arrancamos nuestro auto:
1. poner la llave;
2. asegurarse de que la marcha est en punto muerto;
3. presionar el pedal del acelerador;
4. girar la llave hasta la posicin de arranque;
5. si el motor arranca antes de seis segundos, dejar la llave en posicin ignicin;
6. si el motor no arranca antes de seis segundos, esperar diez segundos y repetir los pasos 3 al 6;
7. si el coche no arranca, llamar al mecnico.
Como vemos, estas simples tareas, se realizan mediante una secuencia lgica de pasos. La mayora de
las cosas que hacemos, se realizan siguiendo una secuencia ordenada de pasos, que alguna vez hemos
aprendido y luego las realizamos sin pensar. Podramos agregar ms ejemplos como cepillarse los
dientes, manejar un automvil, llamar por telfono, ir a cenar, etc. Tambin los matemticos han
Carreras: Analista de Sistemas y Licenciatura en Sistemas
Asignatura: Resolucin de Problemas y Algoritmos
Docente: Lic. Vernica L. Vanoli
Apunte de Ctedra
- Pgina 2 de 165 -
desarrollado secuencias lgicas de pasos para resolver los problemas o demostrar los teoremas. La
produccin o fabricacin de productos (alimentos, electrodomsticos, autos, etc.) se realiza siguiendo
determinadas secuencias lgicas de pasos. Es decir, casi todo esta basado en el orden de las cosas y las
acciones (primero en forma consciente y luego en forma inconsciente). Esta ordenacin se adquiere a
travs de un proceso que podemos llamar programacin.
Programacin: planificacin, proyeccin o ejecucin de una tarea o suceso.
Pero a nosotros, nos interesa en particular la programacin de computadoras para resolver
determinados problemas. Es decir, no usamos computadoras para arrancar un automvil, pero si para
calcular el sueldo de un empleado.
Entonces podramos decir que los pasos para calcular el salario semanal de un empleado son:
1. buscar el sueldo por hora del empleado.
2. determinar el nmero de horas trabajadas durante la semana.
3. s el nmero de horas trabajadas no supera las 40 horas, multiplicar el nmero de horas trabajadas
por el sueldo por horas, para obtener la paga regular.
4. s el nmero de horas trabajadas supera las 40 horas, multiplicar el sueldo por hora por 40 para
obtener la paga regular y multiplicar una vez y media el sueldo por hora por la diferencia, entre el
nmero de horas trabajadas, y 40 para obtener la paga de las horas extras.
5. aadir la paga regular a la paga extra (si la hubiera) para obtener el sueldo total de la semana.
Programacin de computadora: proceso de planificar una secuencia de instrucciones (pasos) que
ha de seguir una computadora.
Programa de computadora: secuencia de instrucciones que indica las acciones que han de ser
ejecutadas por una computadora.
La principal razn por la cual las personas aprenden los lenguajes de programacin y a programar, es
para utilizar la computadora como una herramienta para la resolucin de problemas. La computadora
nos permite hacer tareas ms eficientes, rpidas y precisas. Pero para poder utilizar esta poderosa
herramienta, debemos especificar exactamente lo que queremos hacer y el orden en el que debe
hacerse. Esto se logra mediante la programacin.
Un programa tiene por objetivo resolver un problema. Para desarrollar un programa hemos de seguir
un mtodo, que se compone de las siguientes fases:
1. Anlisis del Problema: comprender (definir) el problema.
2. Diseo del Algoritmo: desarrollar una solucin determinada a partir de una secuencia
lgica de pasos.
3. Implementacin o Codificacin del Algoritmo: traducir el algoritmo a un lenguaje de
programacin.
Carreras: Analista de Sistemas y Licenciatura en Sistemas
Asignatura: Resolucin de Problemas y Algoritmos
Docente: Lic. Vernica L. Vanoli
Apunte de Ctedra
- Pgina 3 de 165 -
Las fases del proceso de resolucin de un problema mediante computadora se indican en la siguiente
figura:
Resolucin de
un problema
Anlisis del
problema
Diseo del
algoritmo
Implementacin
La computadora no puede analizar un problema y proponer una solucin. El programador debe
encontrar la solucin y comunicrsela a la computadora. El programador resuelve el problema, no la
computadora. La computadora es una herramienta que puede ejecutar la solucin (programa) muchas
veces rpidamente.
El primer paso (anlisis del problema) requiere que el problema se defina y comprenda claramente
para poder resolverlo correctamente. Una vez analizado el problema, se debe desarrollar el algoritmo
(procedimiento paso a paso, para solucionar el problema dado). Por ltimo, para resolver el algoritmo
mediante una computadora se necesita codificar el algoritmo en un lenguaje de programacin - Pascal,
Cobol, Fortran, C, etc. -, es decir, convertir el algoritmo en programa, ejecutarlo y comprobar que el
programa soluciona verdaderamente el problema.
Anlisis del Problema
El propsito de esta fase es ayudar al programador para llegar a una comprensin de la naturaleza del
problema. El problema debe estar bien definido si se desea llegar a una solucin satisfactoria.
Para poder definir con precisin el problema se requiere que las especificaciones de entrada y de salida
sean descriptas con detalle. Una buena definicin del problema, junto con una descripcin detallada de
las especificaciones de entrada y de salida, son los requisitos ms importantes para llegar a una
solucin eficaz.
El anlisis del problema exige una lectura previa del problema a fin de obtener una idea general de lo
que se solicita. La segunda lectura deber servir para responder a las preguntas:
- Qu datos se necesitan para resolver el problema? (qu necesito?)
- Qu informacin debe proporcionar la resolucin del problema? (qu se pide?)
La respuesta a la primera pregunta indicar qu datos se proporcionan o las entradas del problema.
La respuesta a la segunda pregunta indicar los resultados deseados o las salidas.
Carreras: Analista de Sistemas y Licenciatura en Sistemas
Asignatura: Resolucin de Problemas y Algoritmos
Docente: Lic. Vernica L. Vanoli
Apunte de Ctedra
- Pgina 4 de 165 -
Anlisis del
problema
Definicin del
problema
Especificacin
de entradas
Especificacin
de salidas
Ejemplos.
Problema: Calcular la superficie y circunferencia de un crculo.
Anlisis
Entradas: Radio del crculo (valor real)
Salidas: Superficie del crculo (valor real)
Circunferencia del crculo (valor real)
Problema: Obtener la calificacin promedio de los resultados obtenidos en el ltimo parcial de la
asignatura Anlisis Matemtico I.
Anlisis
Entradas: Las calificaciones de cada alumno (valores enteros)
Cantidad de calificaciones (valor entero)
Salidas: Promedio (valor real)
Problema: Hallar la cantidad de alumnos que aprobaron el examen de la asignatura Programacin I.
Anlisis
Entradas: Las calificaciones de cada alumno (valores enteros)
Salidas: Cantidad de aprobados (valor entero)
Diseo del Algoritmo
En esta fase el objetivo es obtener la secuencia ordenada de pasos - sin ambigedades - que conducen
a la solucin de un problema dado.
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. As, por ejemplo, en una analoga con la vida diaria, una receta de un plato de
cocina se puede expresar en espaol, ingls o francs, pero cualquiera que sea el lenguaje, los pasos
para la elaboracin del plato se realizarn sin importar el idioma del cocinero.
Caractersticas de los algoritmos:
Un algoritmo debe ser preciso e indicar el orden de realizacin de cada paso.
Un algoritmo debe estar definido. Si se sigue un algoritmo dos veces, se debe obtener el mismo
resultado cada vez.
Carreras: Analista de Sistemas y Licenciatura en Sistemas
Asignatura: Resolucin de Problemas y Algoritmos
Docente: Lic. Vernica L. Vanoli
Apunte de Ctedra
- Pgina 5 de 165 -
Un algoritmo debe ser finito. Si se sigue un algoritmo, se debe terminar en algn momento; o sea
se debe tener un nmero finito de pasos.
La definicin de un algoritmo debe describir tres partes: Entradas, Proceso y Salidas.
Por ejemplo, en un algoritmo de una receta de cocina se tendr:
Entradas: ingredientes y utensilios empleados
Proceso: elaboracin de la receta en la cocina
Salidas: terminacin del plato
Una computadora no tiene capacidad para solucionar problemas ms que cuando se le proporcionan
los sucesivos pasos a realizar. Estos pasos sucesivos que indican las instrucciones a ejecutar por la
mquina constituyen, como ya conocemos, el algoritmo.
La informacin proporcionada al algoritmo constituye su entrada y la informacin producida por el
algoritmo constituye su salida.
Los problemas complejos se pueden resolver ms eficazmente con la computadora cuando se
descomponen en subproblemas que sean ms fciles de solucionar que el original. Este mtodo se
suele denominar divide y vencers. Normalmente los pasos diseados en el primer esbozo del
algoritmo son incompletos e indicarn slo unos pocos pasos. Por lo tanto, luego de esta primera
descripcin, se realiza una ampliacin, obteniendo una descripcin ms detallada con ms pasos
especficos. Este proceso se denomina refinamiento del algoritmo. Para problemas complejos se
necesitan con frecuencia diferentes niveles de refinamiento antes de que se pueda obtener un algoritmo
claro, preciso y completo.
Problema
Subproblema
1
Subproblema
2
Subproblema
3
Subproblema
1.1
Subproblema
1.2
Subproblema
3.1
Subproblema
3.2
Subproblema
3.3
Ejemplos.
Problema: Preparar empanadas.
Anlisis
Entradas: harina, agua, aceite, carne picada, huevos, aceitunas, pasas de uva, cebolla,
condimentos.
Salidas: empanadas.
Diseo
Proceso:
- Preparar la masa de las tapas.
Carreras: Analista de Sistemas y Licenciatura en Sistemas
Asignatura: Resolucin de Problemas y Algoritmos
Docente: Lic. Vernica L. Vanoli
Apunte de Ctedra
- Pgina 6 de 165 -
- Preparar el relleno.
- Armar las empanadas.
- Frer las empanadas.
Preparar
empanadas
Preparar
masa
Armar
empanadas
Preparar
relleno
Frer
empanadas
Pero como sabemos, cada uno de estos pasos se realiza a su vez mediante un conjunto de pasos. Por lo
tanto, cada uno de estos pasos es un problema, o un subproblema del problema original.
Refinamiento:
- Preparar la masa de las tapas.
- Mezclar harina y agua.
- Amasar.
- Dejar reposar 1 hora.
- Preparar el relleno.
- Frer la cebolla.
- Agregar la carne y dejar que se cocine.
- Condimentar.
- Agregar huevo, aceitunas y pasas de uva.
- Armar las empanadas.
- Colocar relleno en el centro de cada tapa.
- Doblar por la mitad.
- Hacer repulgue.
- Frer las empanadas.
Como vemos algunos de estos pasos, podran refinarse an ms.
Problema: Calcular la superficie y circunferencia de un crculo.
Anlisis
Entradas: radio (valor real)
Salidas: superficie, circunferencia (valores reales)
Diseo
Proceso:
- Obtener el radio.
- Calcular la superficie.
- Calcular la circunferencia.
- Mostrar los resultados.
Refinamiento:
- Obtener el radio.
- Calcular la superficie.
- superficie: 3.141592 * radio ^ 2
Carreras: Analista de Sistemas y Licenciatura en Sistemas
Asignatura: Resolucin de Problemas y Algoritmos
Docente: Lic. Vernica L. Vanoli
Apunte de Ctedra
- Pgina 7 de 165 -
- Calcular la circunferencia.
- circunferencia : 2 * 3.141592 * radio
- Mostrar los resultados.
Las ventajas ms importantes del diseo descendente son:
El problema se comprende ms fcilmente al dividirse en partes ms simples denominadas
mdulos.
Las modificaciones en los mdulos son ms fciles.
La comprobacin del problema se puede verificar fcilmente.
Tras los pasos anteriores (diseo descendente y refinamiento por pasos) es preciso representar el
algoritmo mediante una determinada herramienta de programacin: diagrama de flujo, pseudocdigo
o diagrama N-S. En esta asignatura, los algoritmos los vamos a representar en pseudocdigo (casi-
cdigo).
Escritura inicial del algoritmo
El mtodo para describir (escribir) un algoritmo consiste en realizar una descripcin paso a paso con
un lenguaje natural del citado algoritmo. Recordemos que un algoritmo es un mtodo o conjunto de
reglas para solucionar un problema. En clculos elementales estas reglas tienen las siguientes
propiedades:
deben estar seguidas de alguna secuencia definida de pasos hasta que se obtenga un resultado
coherente;
slo puede ejecutarse una operacin a la vez.
Supongamos el siguiente problema: Qu hacer para ver la pelcula Titanic?.
La respuesta es muy sencilla y puede ser descrita en forma de algoritmo general de modo similar a:
- Ir al cine.
- Comprar una entrada.
- Ver la pelcula.
- Regresar a casa.
El algoritmo consta de cuatro acciones bsicas, cada una de las cuales debe ser ejecutada antes de
realizar la siguiente. En trminos de computadora, cada accin se codificar en una o varias sentencias
que ejecutan una tarea particular.
El algoritmo descrito es muy sencillo; sin embargo, como ya se ha indicado en prrafos anteriores, el
algoritmo general se descompondr en pasos ms simples en un procedimiento denominado
refinamiento sucesivo, ya que cada accin puede descomponerse a su vez en otras acciones simples.
- Ver la cartelera de cines en el diario.
- Si no proyectan Titanic
- Decidir otra actividad.
- Sino
- Ir al cine.
- Si hay cola
- Ponerse en ella.
- Mientras haya personas delante
- Avanzar en la cola.
- Si hay localidades
- Comprar una entrada.
Carreras: Analista de Sistemas y Licenciatura en Sistemas
Asignatura: Resolucin de Problemas y Algoritmos
Docente: Lic. Vernica L. Vanoli
Apunte de Ctedra
- Pgina 8 de 165 -
- Pasar a la sala.
- Localizar la(s) butaca(s)
- Mientras proyectan la pelcula
- Ver la pelcula.
- Salir del cine.
- Sino
- Refunfuar.
- Volver a casa.
Podemos continuar refinando este algoritmo, para ello analicemos la accin: - localizar la(s) butacas(s)
- Caminar hasta llegar a la primera fila de butacas.
- Hacer
- Comparar nmero de fila con nmero impreso en billete.
- Si no son iguales
- Pasar a la siguiente fila.
- Mientras que se localice la fila correcta
- Mientras nmero de butaca no coincida con nmero de billete
- Avanzar a travs de la fila a la siguiente butaca.
- Sentarse en la butaca.
Se considera que el nmero de la butaca y fila coincide con el nmero y fila rotulado en el billete.
Para describir un algoritmo hemos de utilizar tres componentes esenciales:
Datos.
Operaciones.
Estructuras de Control.
Datos
El primer objetivo de toda computadora es el manejo de la informacin o datos. Las entradas y las
salidas en un programa son datos. A veces son necesarios datos auxiliares para realizar clculos
intermedios que permiten obtener las salidas finales.
Un algoritmo maneja datos usando variables y constantes. La caracterstica principal de una variable
es que es un dato que puede cambiar o alterar su valor durante la ejecucin del programa. Y una
constante es un dato cuyo valor permanece inalterable durante la ejecucin del algoritmo. Pero en
ambos casos, el dato o valor residir en la memoria de la computadora, y para poder acceder a ellas
usamos un nombre o identificador, que nos permitir referenciarlo en el programa.
Un dato ser una variable o una constante, que utilizaremos mediante su identificador. Los siguientes
pueden ser nombres de variables o constantes: NUM, MAX, EDAD, LETRA, ... Se recomienda, para
mayor claridad y seguimiento de las mismas, colocarle nombres significativos dentro de un programa.
No use espacios, en ese caso escriba de la siguiente manera: NUM_1. Tampoco use acentos.
Las variables son de algn tipo: simple o compuesto (Clases/Objetos). Cada variable y constante es de
un tipo de datos determinado (entero, real, caracter, booleano, etc.). El tipo de datos determina el
conjunto de valores al que pertenece una constante o sobre el cul puede tomar valores una variable, y
el conjunto de operaciones que se pueden realizar sobre el mismo.
Carreras: Analista de Sistemas y Licenciatura en Sistemas
Asignatura: Resolucin de Problemas y Algoritmos
Docente: Lic. Vernica L. Vanoli
Apunte de Ctedra
- Pgina 9 de 165 -
Tipos de Datos Simples
Los tipos de datos simples se clasifican en:
Numrico.
Caracter.
Lgico o Booleano.
Datos de tipo numrico: es el conjunto de los valores numricos. Se representan en dos formas
distintas:
Enteros es un subconjunto finito de los nmeros enteros. Son nmeros completos, no tienen
componentes fraccionarios o decimales y pueden ser negativos o positivos.
Reales es un subconjunto de los nmeros reales. Un nmero real consta de una parte entera, un
punto y una parte decimal; pueden ser negativos o positivos.
Datos de tipo caracter: es el conjunto finito y ordenado de caracteres que la computadora reconoce. Un
dato tipo caracter contiene un solo caracter.
Caracteres Alfabticos pueden ser algunas de las siguientes letras: A, B, C, ..., Z, a, b,
c, ... , z.
Caracteres Numricos pueden ser algunos de los siguientes dgitos: 0, 1, 2, ..., 9.
Caracteres Especiales pueden ser alguno de los siguientes smbolos: +, -, *, /, $, ;,
<, >, #, ...
Datos de tipo lgico (booleano): es aquel dato que slo puede tomar uno de dos valores: Verdadero
(True) o Falso (False). Este tipo de dato se utiliza para representar las alternativas (si/no) a
determinadas condiciones.
Tipos de Datos Compuestos o Clases/Objetos
Los tipos de datos compuestos tambin llamados clases/objetos, se clasifican en: arreglos (vectores y
matrices), cadenas, archivos, pilas, colas, listas, rboles, etc., que se estudiarn mas adelante.
Operaciones
Para manipular datos, es decir, para transformar las entradas en salidas, para que la computadora se
comunique con el exterior y para que podamos introducir datos en la computadora necesitamos
operaciones. Estas operaciones pueden ser:
Asignacin.
Entrada.
Salida.
Operacin de Asignacin
La operacin de asignacin es el modo de darle valores a una variable. La operacin de asignacin se
representa con el smbolo u operador (una flecha apuntando hacia la izquierda). La operacin de
asignacin se conoce como instruccin o sentencia de asignacin cuando se refiere a un lenguaje de
programacin.
Formato general:
nombre_de_la_variable expresin
Carreras: Analista de Sistemas y Licenciatura en Sistemas
Asignatura: Resolucin de Problemas y Algoritmos
Docente: Lic. Vernica L. Vanoli
Apunte de Ctedra
- Pgina 10 de 165 -
Por ejemplo, la operacin de asignacin: A 5. Significa que a la variable A se le ha asignado el
valor entero 5.
La accin de asignar es destructiva, ya que el valor que tuviera la variable antes de la asignacin se
pierde y se reemplaza por el nuevo valor. Es decir que si a la variable A, le vuelvo a asignar otro valor,
por ejemplo el 10, pierde su valor inicial (el 5) y pasa a tener un nuevo valor (el 10).
A una variable se le puede asignar:
un valor, ejemplo: X 3.
otra variable o una constante, ejemplo: X Y. Previo a esto la variable Y deber contener
algn valor.
una expresin aritmtica o lgica, ejemplo: X Y + 3.
En los dos ltimos casos la computadora ejecuta la sentencia de asignacin en dos pasos. En el
primero de ellos se calcula o se obtiene el valor de la expresin del lado derecho del operador,
obtenindose un valor de un tipo especfico. En el segundo paso, este valor se almacena en la variable
cuyo nombre aparece a la izquierda del operador de asignacin, sustituyendo al valor que tena
anteriormente. As, en el ejemplo X Y + 3, el valor del resultado de la expresin Y + 3 se lo
asigna a la variable X.
Veamos algunos ejemplos de asignaciones:
AN 3 + 5 2 se evala la expresin 3+5-2 y se lo asigna a la variable AN, es decir,
6 ser el valor que toma AN.
A 0 la variable A toma el valor 0.
N 2 la variable N toma el valor 2.
A N + 1 la variable A toma el valor N + 1, como N es igual a 2, la variable A
toma el valor 2 + 1, es decir, 3.
Expresiones
Las expresiones son combinaciones de constantes, variables, smbolos de operacin, parntesis y
nombres de funciones especiales. Las mismas ideas son utilizadas en notacin matemtica tradicional.
Cada expresin toma un valor que se determina tomando los valores de las variables y constantes
implicadas y la ejecucin de las operaciones indicadas.
Una expresin consta de operandos y operadores. Segn sea el tipo de objetos que manipulan, las
expresiones se clasifican en:
Aritmticas.
Booleanas.
El resultado de la expresin aritmtica es de tipo numrico y el resultado de la expresin booleana es
de tipo lgico (verdadero o falso).
Expresiones Aritmticas
Son anlogas a las frmulas matemticas. Las variables y constantes son numricas (reales o enteras) y
las operaciones son aritmticas.
Carreras: Analista de Sistemas y Licenciatura en Sistemas
Asignatura: Resolucin de Problemas y Algoritmos
Docente: Lic. Vernica L. Vanoli
Apunte de Ctedra
- Pgina 11 de 165 -
Operador Significado
Exponenciacin
+ Suma
- Resta
* Multiplicacin
/ Divisin
% Resto
Exponenciacin (^)
Tipo de operando Tipo de resultado
Entero Entero
Real Real
Tipo de operando1 Tipo de operador Tipo de operando2 Tipo de resultado
Entero +, -, *, /, % Entero Entero
Entero +, -, *, /, % Real Real
Real +, -, *, /, % Entero Real
Real +, -, *, /, % Real Real
Reglas de Prioridad
Las expresiones que tienen dos o ms operandos requieren reglas matemticas que permitan
determinar el orden de las operaciones, se denominan reglas de prioridad o precedencia y son:
1.- Las operaciones que estn encerradas entre parntesis se evalan primero. Si existen diferentes
parntesis anidados (interiores unos a otros), las expresiones ms internas se evalan primero.
2.- Las operaciones aritmticas dentro de una expresin suelen seguir el siguiente orden de prioridad:
Operador ^
Operadores *, /
Operadores +, -
Operadores %
3.- En caso de coincidir varios operadores de igual prioridad en una expresin o subexpresin
encerrada entre parntesis, el orden de prioridad es de izquierda a derecha.
Algunos ejemplos de prioridad:
Frmula matemtica Expresin algortmica
B
2
- 4AC B 2 - 4 * A * C
A + B C A + B - C
A + B
-----------
C + D
(A + B) / (C + D)
1
---------
1 + X
2
1 / ( 1 + X 2)
AX - ( B + C) A * X - ( B + C)
Carreras: Analista de Sistemas y Licenciatura en Sistemas
Asignatura: Resolucin de Problemas y Algoritmos
Docente: Lic. Vernica L. Vanoli
Apunte de Ctedra
- Pgina 12 de 165 -
Expresiones Booleanas
Una expresin booleana es una expresin que slo puede tomar dos valores: verdadero o falso. Las
expresiones booleanas se forman combinando operandos compatibles mediante operadores
relacionales. Las expresiones booleanas se utilizan principalmente para conformar condiciones.
Operadores relacionales:
Operador Significado
= = Igualdad
< Menor que
> Mayor que
<= Menor o igual que
>= Mayor o igual que
!= Desigualdad o Distinto
Los operadores relaciones o de relacin permiten realizar evaluaciones o comparaciones de los
operandos. El resultado de la operacin ser verdadero o falso.
Formato general:
operando1 operador_de_relacin operando2
Por ejemplo:
Expresin Resultado
1 = = 5 Falso
2 > 1.33 Verdadero
-5 != 5 Verdadero
1.7 <= -3 Falso
En estos ejemplos se han utilizado operandos constantes pero por lo general se utilizan variables.
Por ejemplo:
Suponemos que X: 5 e Y: -2.
Expresin Resultado
X + 1 = = 7 Falso
Y > X - 10 Verdadero
Y * 2 != 4 Verdadero
7 <= X Falso
Las expresiones booleanas pueden ser simples (como los ejemplos vistos) o compuestas. Es decir, los
operandos de una expresin booleana podran ser a su vez subexpresiones booleanas. Se utilizan los
operadores lgicos para componer expresiones booleanas compuestas.
El formato de la expresin general en este caso es:
expresin1 operador_lgico expresin2
Carreras: Analista de Sistemas y Licenciatura en Sistemas
Asignatura: Resolucin de Problemas y Algoritmos
Docente: Lic. Vernica L. Vanoli
Apunte de Ctedra
- Pgina 13 de 165 -
Operadores lgicos o condicionales:
Operador Significado Resultado
& Conjuncin (y) La expresin ser cierta slo si ambos
operandos son ciertos. En cualquier otro caso
ser falsa.
| Disyuncin (o) La expresin ser falsa slo si ambos
operandos son falsos. En cualquier otro caso
ser verdadera.
En estos casos, para evaluar la expresin booleana, se obtiene primero los resultados de las
subexpresiones y con estos resultados se obtiene el resultado de aplicar los operadores lgicos.
Algunos ejemplos:
Suponemos que A: 3 y B: -5.
Expresin Resultado
(A >= 7) & (B = = -5) Falso
(3 != B) | (B < -10) Verdadero
(A = = B + 8) | (B < -4) Verdadero
Operacin de Entrada
Es necesaria una operacin que nos permita ingresar datos en la computadora, para que sta los
procese. Esta operacin, se realizar a travs de una sentencia denominada: LEER. Dicha sentencia
permitir que el dato ingresado por teclado se almacene en una variable. De esta manera el dato podr
ser diferente cada vez que se ejecute el programa.
Formato general:
leer lista_de_variables_de_entrada
Supongamos la sentencia: leer N. Si tipeamos (en el teclado de la computadora) el valor 30, la variable
N valdr 30 (suponemos que N es una variable entera). De esta forma, podemos suministrarle al
programa datos desde su exterior, utilizando variables.
Operacin de Salida
Los programas realizan clculos para producir salidas. Y dichas salidas deben ser informadas a quien
requiere estos resultados, entonces necesitamos una operacin que permita que la computadora
informe resultados y/o texto descriptivo. No tiene sentido que la computadora realice procesos si no
podemos enterarnos de las salidas. Mediante una sentencia denominada: ESCRIBIR, se visualizarn
en la pantalla los resultados de los clculos o texto descriptivo.
Formato general:
escribir lista_de_expresiones_de_salida y/o mensaje_de_salida
Carreras: Analista de Sistemas y Licenciatura en Sistemas
Asignatura: Resolucin de Problemas y Algoritmos
Docente: Lic. Vernica L. Vanoli
Apunte de Ctedra
- Pgina 14 de 165 -
Supongamos la sentencia: escribir Este es mi primer programa. En la pantalla de nuestra
computadora veremos el mensaje: Este es mi primer programa.
Ahora supongamos la sentencia: escribir N. En la pantalla de nuestra computadora veremos el valor
de la variable N. Es decir: 30 (tomando el valor que se ley en el ejemplo de LEER).
Como vemos, para diferenciar entre la escritura de un texto y una variable, en el caso del texto lo
encerramos entre comillas simples. Si queremos combinar variables con texto, van separados con una
coma (,).
Los clculos que realizan las computadoras requieren para ser tiles la entrada de los datos necesarios
para ejecutar las operaciones que posteriormente se convertirn en resultados, es decir, salida.
Las operaciones de entrada permiten leer determinados valores y asignarlos a determinadas variables.
Esta entrada se conoce como operacin de lectura. Los datos de entrada se introducen al procesador
mediante dispositivos de entrada (teclado, mouse, scanner, tarjetas perforadas, unidades de disco, etc.).
La salida puede aparecer en un dispositivo de salida (pantalla, impresora, unidades de disco, parlantes,
etc.). La operacin de salida se denomina escritura.
Ejemplos.
Problema: Obtener dos nmeros enteros y mostrar la suma de los mismos.
Anlisis
Entradas: Dos nmeros (enteros).
Salidas: Suma de los nmeros (entera).
Diseo
Proceso: - Leer los nmeros.
- Sumar los nmeros.
- Mostrar la suma de los nmeros.
Algoritmo
escribir Ingresar los valores a sumar
leer NUM1, NUM2
SUMA NUM1 + NUM2
escribir La suma de los valores ingresados es: , SUMA
Otra forma de escribirlo sera:
escribir * Suma de dos nmeros enteros *
escribir Ingrese el primer nmero
leer NUM1
escribir Ingrese el segundo nmero
leer NUM2
SUMA NUM1 + NUM2
escribir La suma de los valores ingresados es: , SUMA
Carreras: Analista de Sistemas y Licenciatura en Sistemas
Asignatura: Resolucin de Problemas y Algoritmos
Docente: Lic. Vernica L. Vanoli
Apunte de Ctedra
- Pgina 15 de 165 -
Problema: Leer una letra desde el teclado y mostrarla en pantalla tres veces separada por punto y
coma.
Anlisis
Entradas: Letra (caracter).
Salidas: (mensaje).
Diseo
Proceso: - Leer la letra.
- Mostrar la letra tres veces, separada por punto y coma.
Algoritmo
escribir Ingrese una letra
leer LETRA
escribir LETRA, ; , LETRA, ; , LETRA
Nota: Como se aprecia en los ejemplos antes descriptos, las sentencias estn resaltadas en negrita; esto
se debe a que son palabras reservadas, que se diferencian del resto del algoritmo. En el caso de los
algoritmos escritos a mano resalte las palabras reservadas mediante el subrayado de los mismos.
Carreras: Analista de Sistemas y Licenciatura en Sistemas
Asignatura: Resolucin de Problemas y Algoritmos
Docente: Lic. Vernica L. Vanoli
Apunte de Ctedra
- Pgina 16 de 165 -
ESTRUCTURAS DE CONTROL
El orden de ejecucin de las sentencias (enunciados o instrucciones) en un algoritmo se llama flujo de
control. Aunque un flujo normal de un algoritmo es lineal, existen ocasiones en que es necesario salir
del flujo lineal. La forma de manejar el flujo de control en un algoritmo se logra a travs de las
estructuras de control. Estas estructuras pueden ser:
Secuenciacin.
Seleccin.
Iteracin.
Nota: En adelante se utilizan los trminos enunciado, sentencia e instruccin en forma indistinta.
Secuenciacin
La secuenciacin se cumple cuando las sentencias se ejecutan siguiendo el orden fsico, es decir, el
orden en que estn escritas.
Comenzamos con el primero paso, continuamos con el segundo, seguimos con el tercero y as hasta
llegar al fin. Respetando siempre el orden.
Enunciado 1
Enunciado 2
Enunciado 3
.
.
.
Enunciado n
En ningn caso se ejecutar el enunciado 2 antes que el enunciado 1. El orden de ejecucin ser
exactamente como estn escritas.
Ejemplos.
Problema: Calcular la cantidad de segundos que contiene una determinada cantidad de horas.
Anlisis
Entradas: Horas (entero).
Salidas: Segundos (entero).
Diseo
Proceso: - Leer la hora.
- Calcular los segundos que hay esa hora.
- Mostrar los segundos.
Algoritmo
escribir Ingrese una hora para calcularle los segundos
leer HORAS
SEGUNDOS HORAS * 60 * 60
escribir La cantidad de segundos que tiene es: , SEGUNDOS
Carreras: Analista de Sistemas y Licenciatura en Sistemas
Asignatura: Resolucin de Problemas y Algoritmos
Docente: Lic. Vernica L. Vanoli
Apunte de Ctedra
- Pgina 17 de 165 -
Problema: Escribir un algoritmo que dado el peso en libras de un objeto calcule y muestre el mismo en
kilogramos y gramos (1 libra: 0.453592 kilogramos o 1 libra: 453.59237 gramos).
Anlisis
Entradas: Peso en libras (real).
Salidas: Peso en kilogramos y peso en gramos (reales).
Diseo
Proceso: - Leer el peso en libras.
- Calcular el peso en kilogramos del peso en libras.
- Calcular el peso en gramos del peso en libras.
- Mostrar los respectivos pesos.
Algoritmo
escribir Ingrese un determinado peso expresado en libras
leer PESO_LIBRAS
PESO_KG PESO_LIBRAS * 0.453592
PESO_GR PESO_LIBRAS * 453.59237
escribir El peso: , PESO_LIBRAS, (en libras) equivale a: , PESO_KG, kilogramos
escribir El peso: , PESO_LIBRAS, (en libras) equivale a: , PESO_GR, gramos
Problema: Convertir una temperatura de grados Celsius a grados Fahrenheit. (1 Fahrenheit: 9/5 x 1
Celsius + 32).
Anlisis
Entradas: Temperatura en Celsius (entero).
Salidas: Temperatura en Fahrenheit (real).
Diseo
Proceso: - Leer la temperatura en grados Celsius.
- Convertir la temperatura en Fahrenheit.
- Mostrar la temperatura resultante.
Algoritmo
escribir Ingrese una temperatura en grados Celsius
leer CELSIUS
FAHRENHEIT 9/5 * CELSIUS + 32
escribir La temperatura en grados Celsius: , CELSIUS, equivale a: , FAHRENHEIT, grados
Fahrenheit
Seleccin
Esta estructura se utiliza cuando el algoritmo debe elegir (seleccionar) entre dos o ms acciones
posibles. Es decir, el algoritmo debe permitir que se tome una decisin y luego ejecutar una de varias
acciones (caminos) posibles. Tambin se lo conoce con el nombre de Seleccin Dicotmica. Existen
dos tipos de estructuras:
SI-SINO.
ALTERNAR-CASO.
Carreras: Analista de Sistemas y Licenciatura en Sistemas
Asignatura: Resolucin de Problemas y Algoritmos
Docente: Lic. Vernica L. Vanoli
Apunte de Ctedra
- Pgina 18 de 165 -
Estructura SI-SINO
Para poder tomar una decisin debe plantearse una condicin (expresin booleana) que al ser evaluada
dar un resultado que indicar las acciones (otros enunciados o sentencias) a seguir.
Formato general:
si (condicin)
enunciado1
[sino
enunciado2]
La estructura SI-SINO evala cierta condicin. Si el resultado es verdadero ejecuta el enunciado 1,
caso contrario, si el resultado es falso, se ejecuta el enunciado 2. Es importante tener en cuenta que
siempre se ejecutar slo uno de los enunciados (el que le sigue al si o el que le sigue al sino), pero
debemos escribir en el algoritmo ambos.
Las palabras si y sino, son palabras reservadas.
Ejemplos.
Problema: Dado un nmero entero informar si el mismo es positivo o negativo.
Anlisis
Entradas: Nmero (entero).
Salidas: (mensaje).
Diseo
Proceso: - Leer el nmero.
- Decir si es positivo o negativo.
Algoritmo
escribir Ingrese un nmero entero
leer NUM
si (NUM < 0)
escribir El nmero ingresado es negativo
sino
escribir El nmero ingresado es positivo
Problema: Dado un nmero entero determinar si es par o impar.
Anlisis
Entradas: Nmero (entero).
Salidas: (mensaje).
Diseo
Proceso: - Leer el nmero.
- Decir si es par o impar.
Algoritmo
escribir Ingrese un nmero entero
leer NUMERO
Carreras: Analista de Sistemas y Licenciatura en Sistemas
Asignatura: Resolucin de Problemas y Algoritmos
Docente: Lic. Vernica L. Vanoli
Apunte de Ctedra
- Pgina 19 de 165 -
RESTO NUMERO % 2
si (RESTO = = 0)
escribir El nmero ingresado es PAR
sino
escribir El nmero ingresado es IMPAR
Otra manera de escribir dicho algoritmo sera:
escribir Ingrese un nmero entero
leer NUMERO
si (NUMERO % 2 = = 0)
escribir El nmero ingresado es PAR
sino
escribir El nmero ingresado es IMPAR
Como vemos en este ltimo caso, con una sola variable se pudo armar el algoritmo. Cualquiera de las
dos alternativas es vlida.
Problema: Mostrar el valor absoluto de un nmero.
Anlisis
Entradas: Nmero (real).
Salidas: Nmero en valor absoluto (real).
Diseo
Proceso: - Leer el nmero.
- Pasar el nmero a valor absoluto.
- Mostrar el resultado de la transformacin.
Algoritmo
escribir Ingrese un nmero
leer NUM
si (NUM < 0)
ABSNUM (-1) * NUM
sino
ABSNUM NUM
escribir El nmero expresado en valor absoluto es: , ABSNUM
Existen ocasiones, en las que el problema exige que se ejecute una determinada accin si ocurre
determinada condicin, sino no ocurre nada. Como en los siguientes casos:
si (EDAD = = 15)
escribir FELIZ ETAPA!!!
si (DIA = = 25 & MES = = 12)
escribir FELIZ NAVIDAD
Estos casos demuestran que no es necesario incorporar el SINO, ya que en el programa o proceso, la
carencia de dicha instruccin no afecta al desarrollo o resultado del mismo.
Carreras: Analista de Sistemas y Licenciatura en Sistemas
Asignatura: Resolucin de Problemas y Algoritmos
Docente: Lic. Vernica L. Vanoli
Apunte de Ctedra
- Pgina 20 de 165 -
Problema: Dado un ao informar si el mismo es bisiesto o no. Un ao es bisiesto si es mltiplo de 4
(por ejemplo: 1984). Los mltiplos de 100 no son bisiestos, salvo si ellos son tambin mltiplos de
400. (2000 es bisiesto, 1800 no lo es).
Anlisis
Entradas: Ao (entero).
Salidas: (mensaje).
Diseo
Proceso: - Leer el ao.
- Verificar si es bisiesto o no.
- Mostrar el mensaje correspondiente.
Algoritmo
escribir Ingrese un ao determinado
leer ANIO
BISIESTO falso
si (ANIO % 4 = = 0)
BISIESTO verdadero
si (ANIO % 100 = = 0 & ANIO % 400 != 0)
BISIESTO falso
si (BISIESTO = = verdadero)
escribir El ao ingresado es bisiesto
sino
escribir El ao ingresado NO es bisiesto
Supongamos el siguiente problema: Ingresar una temperatura y mostrar qu deporte es apropiado para
esa temperatura, usando los siguientes criterios:
Deporte Temperatura (rangos)
Natacin > 85
Tenis 70 < TEMP <= 85
Golf 32 < TEMP <= 70
Esqu 10 < TEMP <= 32
Damas <= 10
El algoritmo podra ser de la siguiente manera:
escribir Ingrese una temperatura
leer TEMP
si (TEMP > 85)
escribir El deporte adecuado para dicha temperatura es la NATACIN
si (TEMP > 70 & TEMP <= 85)
escribir El deporte adecuado para dicha temperatura es el TENIS
si (TEMP > 32 & TEMP <= 70)
escribir El deporte adecuado para dicha temperatura es el GOLF
si (TEMP > 10 & TEMP <= 32)
escribir El deporte adecuado para dicha temperatura es el ESQU
si (TEMP <= 10)
escribir El deporte adecuado para dicha temperatura es las DAMAS
Carreras: Analista de Sistemas y Licenciatura en Sistemas
Asignatura: Resolucin de Problemas y Algoritmos
Docente: Lic. Vernica L. Vanoli
Apunte de Ctedra
- Pgina 21 de 165 -
El problema de este algoritmo es que cada vez que se ejecuta, se realizan las cinco evaluaciones,
sabiendo que slo ser posible de cumplir una. Lo ms apropiado es plantear este caso con lo que se
conoce como: SI ANIDADO. Si aplicamos este criterio, el algoritmo quedara as:
escribir Ingrese una temperatura
leer TEMP
si (TEMP > 85)
escribir El deporte adecuado para dicha temperatura es la NATACIN
sino
si (TEMP > 70)
escribir El deporte adecuado para dicha temperatura es el TENIS
sino
si (TEMP > 32)
escribir El deporte adecuado para dicha temperatura es el GOLF
sino
si (TEMP > 10)
escribir El deporte adecuado para dicha temperatura es el ESQU
sino
escribir El deporte adecuado para dicha temperatura es las DAMAS
Quizs, este algoritmo es ms complejo de leer, pero es mejor que el anterior puesto que se ejecutarn
a lo sumo cuatro evaluaciones de condiciones (la ltima accin sale por decantacin de un sino).
Como se ve en el algoritmo, tambin se ha logrado acortar las condiciones de los SI, preguntando slo
por una de las partes de los rangos correspondientes.
Estructura ALTERNAR-CASO
Esta estructura permite hacer una seleccin (o alternacin) de mltiples posibilidades. La estructura
ALTERNAR-CASO es una abreviatura de estructuras SI anidadas. Tenemos las siguientes sentencias:
si (X = = valor_constante_1)
enunciado1
sino
si (X = = valor_constante_2)
enunciado2
sino
si (X = = valor_constante_3)
enunciado3
sino
.
.
.
En efecto esta construccin anidada no es ms que una prueba de opcin mltiple sobre el valor de
la variable X. Otra forma ms sencilla y mejorada de escribir dichas sentencias, es a travs de la
estructura ALTERNAR-CASO.
Carreras: Analista de Sistemas y Licenciatura en Sistemas
Asignatura: Resolucin de Problemas y Algoritmos
Docente: Lic. Vernica L. Vanoli
Apunte de Ctedra
- Pgina 22 de 165 -
Formato general:
alternar (expresin)
{
caso valor_1 : {
conjunto_de_sentencias_1
corte
}
caso valor_2 : {
conjunto_de_sentencias_2
corte
}
.
.
.
caso valor_n : {
conjunto_de_sentencias_n
corte
}
[caso contrario
conjunto_de_sentencias_caso_contrario]
}
Las sentencias antes mencionadas, usando la estructura ALTERNAR-CASO, quedarn representadas
de la siguiente manera:
alternar (X)
{
caso valor_constante_1 : {
enunciado_1
corte
}
caso valor_constante_2 : {
enunciado_2
corte
}
caso valor_constante_3 : {
enunciado_3
corte
}
}
Otras consideraciones a tener en cuenta:
Las palabras alternar, caso, caso contrario y corte son palabras reservadas.
La expresin puede ser cualquier expresin de tipo simple que no sea real.
Cada uno de los valores constantes del CASO representa uno de los valores permisibles de la
expresin. As, si la expresin es de tipo entero, los valores constantes del CASO representarn
valores enteros dentro de un rango determinado.
Los valores constantes del CASO no tienen por qu aparecer en un orden particular, aunque cada
uno de ellos debe ser nico, es decir, no puede aparecer un mismo rtulo ms de una vez.
Carreras: Analista de Sistemas y Licenciatura en Sistemas
Asignatura: Resolucin de Problemas y Algoritmos
Docente: Lic. Vernica L. Vanoli
Apunte de Ctedra
- Pgina 23 de 165 -
Una sentencia se ejecutar si (y slo s) uno de sus valores constantes del CASO correspondiente
coincide con el valor actual de la expresin. Por lo tanto, el valor actual de la expresin
determinar cul de las sentencias se va a ejecutar. Si el valor de la expresin no coincide con
ninguno de los valores constantes, y no se encuentra definida la instruccin CASO CONTRARIO,
la accin a realizar estar indefinida. Es decir, se ejecutar la estructura ALTERNAR-CASO, pero
no ocurrir nada.
La estructura ALTERNAR-CASO, slo se utiliza para comparaciones de igualdad. Es decir, no se
pueden utilizar los operadores relacionales <, >, <=, y >=.
La palabra CORTE produce que luego de ejecutarse los enunciados de un CASO (verdadero) el
flujo de control salga de la estructura ALTERNAR-CASO, evitando as realizar evaluaciones
innecesarias (casos restantes).
En el siguiente ejemplo se supone que la variable OPCION es de tipo caracter:
alternar (OPCION)
{
caso A : {
escribir Alfa
corte
}
caso B : {
escribir Beta
corte
}
caso G : {
escribir Gama
corte
}
caso contrario
escribir No es una letra del alfabeto griego
}
En este ejemplo, si la variable caracter tiene el valor A se mostrar el mensaje Alfa, si tiene el
valor B se mostrar el mensaje Beta y si tiene el valor G se mostrar el mensaje Gama, sino
(en cualquier otro caso) se mostrar el mensaje No es una letra del alfabeto griego.
Ejemplos.
Problema: Dado el nmero correspondiente a un mes, mostrar el nombre de dicho mes. Por ejemplo:
si el nmero es 1 el nombre correspondiente es ENERO.
Anlisis
Entradas: Nmero (entero).
Salidas: (mensaje).
Diseo
Proceso: - Leer el nmero del mes.
- Verificar cul es su nombre.
- Mostrar el nombre correspondiente.
Carreras: Analista de Sistemas y Licenciatura en Sistemas
Asignatura: Resolucin de Problemas y Algoritmos
Docente: Lic. Vernica L. Vanoli
Apunte de Ctedra
- Pgina 24 de 165 -
Algoritmo
escribir Trabajando con los meses, ingrese un nmero entero
leer MES
escribir El nombre correspondiente al nmero del mes ingresado es:
alternar (MES)
{
caso 1 : {
escribir ENERO
corte
}
caso 2 : {
escribir FEBRERO
corte
}
caso 3 : {
escribir MARZO
corte
}
caso 4 : {
escribir ABRIL
corte
}
caso 5 : {
escribir MAYO
corte
}
caso 6 : {
escribir JUNIO
corte
}
caso 7 : {
escribir JULIO
corte
}
caso 8 : {
escribir AGOSTO
corte
}
caso 9 : {
escribir SEPTIEMBRE
corte
}
caso 10 : {
escribir OCTUBRE
corte
}
caso 11 : {
escribir NOVIEMBRE
corte
}
Carreras: Analista de Sistemas y Licenciatura en Sistemas
Asignatura: Resolucin de Problemas y Algoritmos
Docente: Lic. Vernica L. Vanoli
Apunte de Ctedra
- Pgina 25 de 165 -
caso 12 : {
escribir DICIEMBRE
corte
}
caso contrario
escribir NUMERO DE MES INCORRECTO
}
Problema: Leer dos nmeros enteros y leer un smbolo, si dicho smbolo se encuentra entre los
operadores +, - *, /, y ^, por cada unos de ellos efectuar las operaciones correspondientes. En el caso
de la suma, evaluar el resultado si es par o impar, en el caso de la resta, evaluar el resultado si es
negativo o positivo y en el caso de la divisin, determinar si el resultado es igual a 12.00. Devolver los
resultados y mensajes correspondientes.
Anlisis
Entradas: Nmeros (entero) y smbolo (caracter).
Salidas: Resultado (entero o real) y (mensaje).
Diseo
Proceso: - Leer los nmeros.
- Leer el smbolo.
- Determinar el tipo de smbolo.
- Realizar la operacin y evaluacin correspondiente.
- Mostrar los resultados y mensajes correspondientes.
Algoritmo
escribir Trabajando con los operadores
escribir Ingrese el primer operador entero
leer NUM1
escribir Ingrese el segundo operador entero
leer NUM2
escribir Ingrese un smbolo cualquiera (+, -, *, /, ^, ...)
leer SIMB
alternar (SIMB)
{
caso + : {
RESUL NUM1 + NUM2
si (RESUL % 2 = = 0)
escribir El resultado de la suma es PAR
sino
escribir El resultado de la suma es IMPAR
corte
}
caso - : {
RESUL NUM1 - NUM2
si (RESUL > 0)
escribir El resultado de la resta es POSITIVO
sino
escribir El resultado de la resta es NEGATIVO
corte
Carreras: Analista de Sistemas y Licenciatura en Sistemas
Asignatura: Resolucin de Problemas y Algoritmos
Docente: Lic. Vernica L. Vanoli
Apunte de Ctedra
- Pgina 26 de 165 -
}
caso * : {
RESUL NUM1 * NUM2
corte
}
caso / : {
RESUL NUM1 / NUM2
si (RESUL = = 12.00)
escribir El resultado de la divisin es igual al nmero 12.00
sino
escribir El resultado de la divisin NO es igual al nmero 12.00
corte
}
caso ^ : {
RESUL NUM1 ^ NUM2
corte
}
caso contrario
escribir Operador incorrecto
}
escribir NUM1, , SIMB, , NUM2, = , RESUL
Como vemos en los dos problemas anteriores, las sentencias pueden ser simples o compuestas. En el
caso de tratarse de una sentencia compuesta con varias operaciones, se incorporan la llave de apertura
{ y la llave de cierre }, que delimitan el bloque correspondiente a la sentencia. No es necesario
escribirlas cuando existe una sola sentencia, pero no es un error hacerlo y se recomienda para mayor
claridad.
Nota: A partir de este momento, cada vez que escribamos un algoritmo, vamos a iniciarlo con una
llave de apertura principal y vamos a concluirlo con una llave de cierre principal. Es decir, el
algoritmo quedar delimitado entre llaves.
Iteracin
Esta estructura de control, como su nombre lo indica, posibilita repetir la ejecucin de una sentencia o
un conjunto de sentencias.
Anteriormente hemos visto que en la secuencia el flujo de control sigue el orden fsico de las
sentencias, por lo tanto, diremos que el orden lgico (orden en que queremos que se ejecuten las
sentencias) es igual que el orden fsico. En cambio en la seleccin el flujo de control difiere del orden
fsico de las sentencias, en este caso el orden fsico y el orden lgico son diferentes. En la iteracin el
orden lgico tambin difiere del orden fsico de las instrucciones. Una iteracin se conoce tambin
como bucle o ciclo.
Existen tres tipos de estructuras que nos permiten iterar acciones:
MIENTRAS.
HACER-MIENTRAS.
PARA.
Nota: En adelante se usan de manera indistinta los trminos bucle, ciclo e iteracin.
Carreras: Analista de Sistemas y Licenciatura en Sistemas
Asignatura: Resolucin de Problemas y Algoritmos
Docente: Lic. Vernica L. Vanoli
Apunte de Ctedra
- Pgina 27 de 165 -
Estructura MIENTRAS
Esta sentencia evala una condicin (expresin booleana), si esta condicin es verdadera ejecuta el
enunciado, vuelve atrs (o arriba) y evala de nuevo la condicin. Este proceso se repetir hasta que la
condicin sea falsa. Cuando al evaluar la condicin, esta da un resultado falso, ejecuta la prxima
sentencia fuera de la iteracin o bucle y no vuelve atrs.
Formato general:
mientras (condicin)
enunciado1
Evala cierta condicin booleana. Si el resultado es verdadero, ejecuta el enunciado 1 y contina de
esta manera mientras la condicin siga siendo verdadera.
Es claro que el ciclo se romper cuando la condicin deje de ser verdadera, es decir, se vuelva falsa.
Es posible incluso que el ciclo nunca se efecte si de entrada la condicin es falsa. Es decir, que la
condicin inicialmente sea falsa, por lo tanto, no entrar al bucle ni siquiera una vez. En el siguiente
ejemplo, si la primera vez que se lee X, se lee 1, la condicin X >= 0 es inicialmente falsa, por lo
tanto, no ejecutar ni siquiera una vez los enunciados que estn dentro del bucle.
leer X
mientras (X >= 0)
{
escribir X
leer X
}
A primera vista puede parecer que SI y MIENTRAS son parecidas. Tienen similitudes, pero un
examen cuidadoso muestra sus diferencias fundamentales. En la estructura SI, el enunciado 1 puede
ser saltado o ejecutado exactamente una vez. En la estructura MIENTRAS, el enunciado 1 puede ser
saltado o ejecutado una y otra vez, varias veces.
si (condicin) mientras (condicin)
enunciado1 enunciado1
enunciado 2 enunciado 2
Cada vez que se ejecuta el cuerpo del bucle (enunciados que deseamos que se repitan), decimos que se
ha producido un paso a travs del bucle. Este paso se llama una iteracin del bucle. Cuando se ha
realizado el ltimo paso a travs de un bucle y el flujo de control procede con la primera sentencia que
va a continuacin del bucle, decimos que se ha salido del bucle. La condicin que produce que se
salga del bucle se llama condicin de terminacin, que es simplemente la expresin booleana que al
ser evaluada en la estructura MIENTRAS dio como resultado Falso.
Supongamos que vamos a pintar las paredes de nuestro dormitorio, y las instrucciones de la pintura
que hemos comprado dicen: aplicar tres manos de pintura, entonces ejecutaremos esta tarea
contando tres veces. Pero si las instrucciones dicen aplicar tantas manos de pintura hasta obtener el
color de la muestra ejecutaremos esta tarea una cantidad de veces que al principio desconocemos.
De lo anterior podemos hacer una clasificacin en dos tipos principales de bucles:
Controlados por contador.
Controlados por sucesos.
Carreras: Analista de Sistemas y Licenciatura en Sistemas
Asignatura: Resolucin de Problemas y Algoritmos
Docente: Lic. Vernica L. Vanoli
Apunte de Ctedra
- Pgina 28 de 165 -
Bucles controlados por contador
Un bucle controlado por contador es un bucle que se ejecuta o se repite un nmero especificado
(conocido) de veces. Hace uso de una variable llamada variable de control de bucle (VCB).
Hay tres partes en un bucle controlado por contador:
1. Inicializar la variable VCB.
2. Comparar la VCB.
3. Incrementar o decrementar la VCB.
Estas operaciones siempre deben estar acompaadas y son necesarias para que la estructura funcione.
Veamos un ejemplo:
CONT 1 * Inicializacin *
mientras (CONT <= 10) * Comparacin *
{
.
.
.
CONT CONT + 1 * Incremento *
}
CONT es la variable de control de bucle. Se inicializa en 1 antes del bucle. La estructura MIENTRAS
compara la expresin CONT <= 10 y ejecuta las sentencias del cuerpo del bucle si es verdadera. La
ltima sentencia del cuerpo del bucle incrementa CONT sumndole 1. Al utilizar enunciados de la
forma: variable variable + 1, en el cuerpo del bucle hacemos que se incremente repetidamente en
1 el valor de la variable. Cada vez que se ejecuta el enunciado, se aade 1 al valor anterior de la
variable y este resultado sustituye al valor anterior. La variable de control de un bucle controlado por
contador siempre es un contador.
La estructura MIENTRAS siempre prueba primero la condicin de terminacin. Si la condicin es
Falsa al principio, nunca se ejecutar el cuerpo del bucle. Es responsabilidad del programador ver que
la condicin que ha de compararse se fije correctamente (inicializacin) antes de que comience la
sentencia MIENTRAS.
El programador debe tambin asegurarse de que la condicin cambia dentro del bucle de forma que se
pueda convertir en Falso en algn momento; si no ocurre as, el bucle nunca terminar. Un bucle cuya
condicin de terminacin nunca se hace falsa se llama bucle infinito, esto significa que tampoco
terminar el algoritmo y el programa se ejecutar errneamente, puesto que no finaliza.
Cuntas veces se ejecuta el bucle del ejemplo anterior: 9 o 10?. Para determinar el nmero de veces,
examinamos el valor al que se inicializ la variable de control del bucle y luego vemos cul es el valor
final que toma. En este caso, CONT (la variable de control de bucle) se inicializ en 1. La
comparacin indica que el cuerpo del bucle se ejecutar mientras que CONT sea menor o igual que 10.
Esto es, el cuerpo del bucle se ejecutar por cada valor de CONT hasta 10 y saltar cuando CONT se
haga 11. Si CONT comienza en 1 y llega hasta 10, esto significa que el cuerpo del bucle se ejecutar
10 veces. Si quisiramos ejecutar el bucle 11 veces, podramos haber inicializado la variable CONT en
0 o cambiando la comparacin a CONT <= 11.
Carreras: Analista de Sistemas y Licenciatura en Sistemas
Asignatura: Resolucin de Problemas y Algoritmos
Docente: Lic. Vernica L. Vanoli
Apunte de Ctedra
- Pgina 29 de 165 -
Bucles controlados por sucesos
Hay varios tipos de bucles controlados por sucesos:
controlados por centinelas;
controlados por indicador;
controlados por EOF y;
controlados por EOLN.
Los dos ltimos se vern mas adelante con Archivos. El factor comn de todos estos bucles es que la
condicin de terminacin depende de algn suceso que ocurre durante la ejecucin del cuerpo del
bucle que seala que el proceso de iteracin debe terminar.
Bucles controlados por centinelas: Los bucles se utilizan frecuentemente para leer y procesar grandes
listas de datos. Cada vez que se ejecuta el cuerpo del bucle, se lee un nuevo dato y luego se procesa.
Sin embargo, hay un problema con este proceso: Cmo decide el programa cuando parar el ciclo de
proceso de lectura y salir del bucle?.
Una solucin frecuente a este problema consiste en un utilizar un dato especial llamado centinela.
Este valor, es una seal de que no hay que procesar mas datos. En otras palabras, la lectura de un
centinela es el suceso que controla el proceso de iteracin. El proceso contina mientras que los
valores ledos no sean el centinela. Se sale del bucle cuando se reconoce al centinela.
Un centinela debe elegirse con cuidado. No puede ser un valor normal. Un centinela debe ser algo que
nunca sea un valor posible entre los datos utilizados. Por ejemplo, si un programa lee fechas de
calendario, podramos usar una variable da igual a 0 como centinela. Tal bucle podra tener la
siguiente forma:
leer DIA * Obtencin del primer valor de centinela *
mientras (DIA != 0) * Comparacin del centinela *
{
.
.
.
leer DIA * Obtencin del nuevo valor de centinela *
}
En este ejemplo cuando se lea 0 en la variable DIA, finalizar la iteracin. Como podemos observar, la
primera vez se lee el centinela antes de entrar al bucle, lo cual se conoce como lectura adelantada, de
esta forma se inicializa el centinela con valores reales. Dentro del cuerpo del bucle, primero se
procesan los datos y al final del cuerpo del bucle obtenemos el nuevo valor para el centinela. Si
olvidamos hacer este ltimo paso, tendremos un bucle infinito, el bucle que nunca termina.
Partes de un bucle controlado por centinela:
1. Obtener (leer o asignar) el valor de la variable centinela.
2. Comparar la variable centinela.
3. Procesar los datos.
4. Obtener el nuevo valor de la variable centinela.
Bucles controlados por indicador: Un indicador es una variable booleana que se utiliza para controlar
el flujo lgico de un programa. Podemos colocar una variable booleana en Verdadero antes de un
MIENTRAS y luego cuando queramos detener la ejecucin del bucle, colocarla en Falso. Esto es, se
utiliza una variable booleana para registrar si se ha producido o no el suceso que controla el proceso.
Carreras: Analista de Sistemas y Licenciatura en Sistemas
Asignatura: Resolucin de Problemas y Algoritmos
Docente: Lic. Vernica L. Vanoli
Apunte de Ctedra
- Pgina 30 de 165 -
Por ejemplo, a continuacin se realiza una lectura de nmeros y se muestran los valores hasta que el
dato contenga un valor negativo.
POSITIVO Verdadero * Inicializacin del indicador *
mientras (POSITIVO = = Verdadero)
{
leer NUMERO
si (NUMERO < 0) * Comparacin del valor ledo *
POSITIVO Falso * Cambio del indicador *
sino
escribir NUMERO
}
Los bucles controlados por centinelas pueden codificarse con indicador. No estamos limitados a
inicializar el indicador siempre en verdadero. Podemos inicializarlo en Falso y cuando ocurra el suceso
cambiarlo a Verdadero para detener la iteracin.
Hemos examinado de qu forma utilizar bucles para aceptar el flujo de control de nuestro programa.
Pero la iteracin por s misma no hace nada. El cuerpo del bucle debe ejecutar una tarea a efectos de
que el bucle sea til. Algunas subtareas iterativas muy frecuentes son:
Bucles contadores.
Bucles sumadores o acumuladores.
Bucles contadores
El bucle del siguiente ejemplo incluye una variable contadora; sin embargo, el bucle no es un bucle
controlado por contador. En un bucle controlado por contador se utiliza la variable contador y la
condicin de terminacin del bucle depende del valor de dicho contador. Como demuestra el siguiente
ejemplo, hay otros usos para un contador distintos a los de controlar la ejecucin del bucle.
Una subtarea frecuente es llevar la cuenta de cuantas veces se ejecuta el bucle, aunque este contador
no se utilice para controlar la ejecucin del bucle. En el ejemplo propuesto, se desea saber cuantos
caracteres distintos de . se han ledo.
CONT 0 * Inicializacin del contador *
leer CARACTER * Lectura del primer caracter *
mientras (CARACTER != .)
{
CONT CONT + 1 * Incremento del contador *
leer CARACTER * Lectura del prximo caracter *
}
escribir CONT
El bucle contina hasta que se lee un punto. En la terminacin del bucle, la variable CONTADOR
contiene la cantidad de caracteres ledos, distintos del caracter punto. Al salir del bucle se muestra
dicho resultado. Se utiliza una lectura adelantada porque este bucle esta controlado por centinela. La
variable CONTADOR de este ejemplo se llama contador de iteracin, porque su valor es igual al
nmero de iteraciones del bucle.
Bucles acumuladores o sumadores
Supongamos que deseamos obtener la suma de 10 valores.
Carreras: Analista de Sistemas y Licenciatura en Sistemas
Asignatura: Resolucin de Problemas y Algoritmos
Docente: Lic. Vernica L. Vanoli
Apunte de Ctedra
- Pgina 31 de 165 -
CONT 1 * Inicializacin de la variable de control *
SUMA 0 * Inicializacin de la suma *
mientras (CONT <= 10)
{
leer NUMERO * Lectura del valor *
SUMA SUMA + NUMERO * Aadido del valor a suma *
CONT CONT + 1 * Incremento de la variable de control *
}
escribir SUMA * Muestra de la suma *
Este bucle esta controlado por contador. Cuando se haya ejecutado este algoritmo, la variable SUMA
contendr la suma de los 10 valores ledos. CONT contendr 11 y NUMERO contendr el ltimo
valor ledo.
Veamos otro ejemplo. Supongamos que queremos obtener la suma de los primeros 10 valores pares
ledos.
CONT 1 * Inicializacin de la variable de control *
SUMA 0 * Inicializacin de la suma *
mientras (CONT <= 10)
{
leer NUMERO * Lectura del valor *
si (NUMERO % 2 = = 0)
{
SUMA SUMA + NUMERO * Aadido del valor a suma *
CONT CONT + 1 * Incremento de la variable de control *
}
}
escribir SUMA * Muestra de la suma *
Se parece mucho al ejemplo anterior, slo que incrementa a CONT y agrega a SUMA slo si el valor
ledo es un nmero par. En este caso al finalizar la iteracin, no sabemos cuantas veces se iter.
En este caso, CONT es un contador de sucesos, porque slo se incrementa si ocurre determinado
suceso.
Cmo disear bucles?
El diseo de un bucle es esencialmente una materia de determinacin de qu condicin debe existir al
comienzo de cada paso del bucle para que funcione correctamente. La caracterstica clave de estas
condiciones es qu es verdad al comienzo de cada iteracin del bucle. Debido a que son siempre
verdad al comienzo de cada iteracin, estas condiciones se llaman invariantes del bucle.
Invariante del bucle: son las condiciones que deben existir al comienzo de cada iteracin de un bucle
particular para que el bucle se ejecute correctamente.
La invariante del bucle no es simplemente la condicin de la estructura MIENTRAS, que determina si
el cuerpo del bucle se ejecuta o no. Las otras condiciones que forman la invariante, y que deben
tambin considerarse, son cosas tales como: la actualizacin de contadores, sumadores, etc.
Carreras: Analista de Sistemas y Licenciatura en Sistemas
Asignatura: Resolucin de Problemas y Algoritmos
Docente: Lic. Vernica L. Vanoli
Apunte de Ctedra
- Pgina 32 de 165 -
Veamos un ejemplo de condicin invariante. Si un problema nos pide sumar los primeros 10 enteros
impares ledos, la variable que lleva el contador de los enteros impares debe comenzar en 0 y puede
aumentar hasta 10. Si el contador va mas all de este rango, hay algo errneo en el diseo del bucle.
Otra condicin invariante de este problema nos exigir que el valor del contador sea igual al nmero
de impares que haya en la entrada. Esto puede parecer obvio, pero tiene sus implicaciones: el contador
debe ser inicializado en 0 (ningn nmero impar ha sido ledo al principio) y debe incrementarse cada
vez que se introduce un nmero impar (no cada vez que se ejecuta el bucle). Ahora sabemos que el
algoritmo para el bucle debe contener al menos los siguientes pasos:
Inicializacin de CONTIMPARES
mientras (CONTIMPARES sea menor o igual que 10)
{
.
.
.
si (NUMERO es impar)
Incremento de CONTIMPARES
.
.
.
}
Podemos entonces traducir este algoritmo en las siguientes sentencias:
CONTIMPARES 0
mientras (CONTIMPARES <= 10)
{
.
.
.
si (NUMERO % 2 != 0)
CONTIMPARES CONTIMPARES + 1
.
.
.
}
Pero este algoritmo no es suficiente para que se ejecute el bucle correctamente. An debe aadirse otra
condicin al invariante y es que el nuevo valor debe estar disponible en la entrada al comienzo de cada
iteracin. Para asegurar que es un nuevo valor para cada iteracin, debe haber una sentencia del bucle
que lea un nuevo valor durante cada iteracin. La sentencia LEER requerida debe insertarse antes de
la sentencia SI, porque la sentencia SI compara el nuevo valor.
La invariante del bucle es:
1. El valor del contador est en el rango de 0 a 10, inclusive.
2. El valor del contador debe ser igual a la cantidad de nmeros impares que se hayan ledo.
3. Debe estar disponible un nuevo valor en la entrada al comienzo de cada iteracin.
Carreras: Analista de Sistemas y Licenciatura en Sistemas
Asignatura: Resolucin de Problemas y Algoritmos
Docente: Lic. Vernica L. Vanoli
Apunte de Ctedra
- Pgina 33 de 165 -
El algoritmo revisado es:
CONTIMPARES 0
mientras (CONTIMPARES <= 10)
{
leer NUMERO
si (NUMERO % 2 != 0)
CONTIMPARES CONTIMPARES + 1
}
Este algoritmo es suficiente para realizar lo que requiere el problema. Sin embargo, an no est
completo. Debemos aadir una sentencia ESCRIBIR antes de LEER para solicitar al usuario que
introduzca un nmero y otra fuera del bucle para mostrar los resultados del proceso.
Determinacin del invariante de un bucle: la escritura del invariante de un bucle es una buena forma
de comenzar a alumbrar todas las cosas que deben hacerse para que un bucle funcione correctamente.
Una vez que se hayan determinado las operaciones esenciales podemos volver atrs y aadir las
operaciones no esenciales que refuerzan el algoritmo o ejecutan tareas extras.
Cmo determinar todas las condiciones que forman el invariante de un bucle?. Esto no es siempre
fcil de hacer, e incluso los programadores con experiencia ocasionalmente dejan una o ms de las
condiciones invariantes cuando disean un bucle. Sin embargo, hay un conjunto de preguntas que nos
pueden ayudar a comenzar en forma correcta:
1. Cul es la condicin que termina el bucle?.
2. Cmo debe inicializarse y actualizarse dicha condicin?.
3. Cul es el proceso que se repite?.
4. Cmo debe inicializarse y actualizarse el proceso?.
El diseo de un bucle puede dividirse en dos tareas: diseo del flujo de control y diseo del
procesamiento que tiene lugar en el bucle. Las dos primeras preguntas nos ayudaran a disear las
partes del bucle que controlan su ejecucin. Las ltimas dos preguntas nos ayudaran a disear el
procesamiento dentro del cuerpo del bucle. Examinemos mas detalladamente cada una de estas tareas
del diseo y sus correspondientes preguntas.
Diseo del flujo de control de un bucle
En esta parte debemos examinar la condicin de terminacin del bucle. El aspecto ms importante de
un bucle es decidir que har que se detenga el bucle. Si la condicin de terminacin no est bien
pensada, existen grandes posibilidades de caer en bucles infinitos y otros errores. As pues, nuestra
primera pregunta al comenzar un bucle debe ser: Cul es la condicin de terminacin del bucle?.
La otra forma de ver esto es: Qu condicin debe ser Verdad para que el bucle termine?. Esta
pregunta puede ser respondida normalmente mediante un examen minucioso de la declaracin del
problema, por ejemplo:
Frase clave de la declaracin del problema Condicin de terminacin
Suma de las 365 temperaturas diarias El bucle termina cuando un contador alcance 366
(controlado por contador).
Hasta que se hayan ledo 10 enteros
impares
El bucle termina cuando se hayan ledo 10 nmeros
impares (controlado por sucesos).
El final de los datos se indica por una
puntuacin negativa del examen
El bucle termina cuando se haya encontrado un valor
negativo de entrada (controlado por centinela).
Carreras: Analista de Sistemas y Licenciatura en Sistemas
Asignatura: Resolucin de Problemas y Algoritmos
Docente: Lic. Vernica L. Vanoli
Apunte de Ctedra
- Pgina 34 de 165 -
Una vez que hayamos determinado la condicin de terminacin del bucle, podemos escribir la parte
del invariante que se convertir en la condicin de la sentencia MIENTRAS. Esencialmente, el
invariante es justo lo opuesto de la condicin de terminacin. Esto es as debido a que la condicin de
la sentencia del MIENTRAS debe convertirse en Falsa para que termine el bucle. Escribimos la
correspondiente condicin en el invariante para expresar el hecho de que debe ser Verdadero para que
el bucle sea ejecutado.
Por ejemplo,
CONTTEMP debe ser menor a 366.
CONTIMPAR debe ser menor o igual que 10.
Podemos ver que estos ejemplos son exactamente los opuestos de las condiciones de terminacin.
Todas las condiciones invariantes son sentencias sobre lo que debe ser Verdad al comienzo de una
iteracin para que la iteracin se ejecute correctamente.
La simple determinacin de la apropiada condicin de terminacin no es suficiente para asegurar que
el bucle termina o que se ejecutar. Debemos tambin incluir sentencias que aseguren que el bucle
comenzar correctamente y producir que el bucle alcance la condicin de terminacin. La siguiente
pregunta a responder es: Cmo debe inicializarse y actualizarse la condicin?. La respuesta depende
del tipo de condicin de terminacin.
Veamos algunos ejemplos:
Controlado por centinela: una lectura adelantada puede ser la nica inicializacin requerida en un
bucle controlado por centinela.
- Al comienzo de cada iteracin debe leerse un nuevo valor (esto implica una lectura adelantada
antes de la primera iteracin y una lectura actualizada al final de cada iteracin).
Contador de iteraciones y contador de sucesos: a la variable contador debe drsele un valor inicial.
En un bucle controlado por contador este valor inicial ser normalmente 1. Si la variable contador es
para contar sucesos dentro del bucle, normalmente ser 0. Si el proceso requiere que el contador vaya
en un rango especifico de valores, el valor inicial debe ser el valor mas bajo del rango.
La operacin de actualizacin en un bucle contador requiere que el valor del contador se
incremente en 1 en cada iteracin o suceso (ocasionalmente encontraremos algn problema que
requiere un contador que decremente o que incremente en mas de una unidad).
- CONTTEMP debe ser igual al nmero de la iteracin que se est ejecutando (esto implica
inicializar en 1 e incrementar en 1 en cada iteracin).
- CONTIMPAR debe ser igual al nmero de enteros impares que se hayan ledo (esto implica
inicializar en 1 e incrementar en 1 cada vez que se lea un entero impar).
Controlado por indicador: la variable indicadora booleana debe inicializarse en Verdadero o Falso,
segn lo apropiado. Por ejemplo:
- ENCONTRADO debe ser igual a Falso al comienzo de cada iteracin.
- POSITIVO debe ser igual a Verdadero al comienzo de cada iteracin.
La operacin de actualizacin es algo diferente en un bucle controlado por indicador, a otros bucles.
La variable indicadora permanece esencialmente sin cambiar hasta que llega el momento de terminar
el bucle. Alguna condicin dentro del proceso que se repite detectar y producir una sentencia de
asignacin para cambiar el valor del indicador. Puesto que la actualizacin depende del proceso,
hemos de disear el proceso antes de disear la operacin de actualizacin en un bucle controlado por
indicador.
Carreras: Analista de Sistemas y Licenciatura en Sistemas
Asignatura: Resolucin de Problemas y Algoritmos
Docente: Lic. Vernica L. Vanoli
Apunte de Ctedra
- Pgina 35 de 165 -
Diseo del proceso interior del bucle
Este proceso debe primero decidir qu ha de realizarse en cada iteracin. Ignoramos el bucle,
suponiendo por un momento que el proceso se va a ejecutar solo una vez. Qu tarea debe ejecutar el
proceso?. En otras palabras, Cul es el proceso que se va a repetir?. Para responder a esta pregunta
debemos examinar la declaracin del problema; por ejemplo:
Hallar la suma de los primeros 100 nmeros mltiplos de 3. Este enunciado nos dice que el
proceso a repetir es una operacin de suma.
Leer un sueldo bruto por cada empleado de una empresa y calcular el sueldo neto. En este caso
debemos repetir la lectura de un dato y luego el clculo.
La lectura, conteo y suma son operaciones que se utilizan frecuentemente en los procesos iterativos.
Otro proceso frecuente en los bucles implica la lectura de datos, la ejecucin de un clculo y la
escritura de resultados. Hay muchas otras operaciones que pueden aparecer en los procesos iterativos,
los mencionados aqu son slo los ejemplos ms sencillos.
Despus que hallamos determinado las operaciones bsicas que hay que ejecutar, podemos disear las
partes del proceso que son necesarias para el bucle. Cuando se coloca un proceso en el cuerpo del
bucle, frecuentemente tenemos que aadir algunos pasos para tener en cuenta el hecho de que se
ejecutan mas de una vez. Esta parte del diseo implica normalmente la inicializacin de ciertas
variables antes de entrar en el bucle y luego la reinicializacin o actualizacin de las variables antes de
que se vaya al siguiente paso del bucle. Por lo tanto, debemos preguntar, Cmo debe inicializarse y
actualizarse el proceso?. Esto depender de que tipo de proceso se trate. Si el proceso es una
operacin de suma, implica la inicializacin en 0 y la actualizacin aadindole datos a la suma. Esto
puede ser expresado por un invariante de la forma:
- Al comienzo de cada iteracin, SUMA debe ser igual al total de todos los mltiplos de 3 que
se hayan ledo.
Esta condicin implica que antes de que se haya ledo cualquier nmero, SUMA es igual a 0.
Un tipo similar de invariante puede usarse para describir las operaciones de conteo de sucesos:
- Al comienzo de cada iteracin, CONTADOR debe ser igual al nmero de sucesos que haya
ocurrido.
A veces el proceso de un bucle requerir varias sumas diferentes y que se realicen varias cuentas. Cada
uno de stos tendr su propia condicin invariante, lo cual significa simplemente que habr ms
sentencias para inicializar variables, ms sentencias para realizar sumas y ms sentencias para
incrementar o decrementar variables contadores. Tratar cada operacin de suma o de conteo por s
misma: primero escribir el invariante para la operacin especifica, luego escribir la sentencia de
inicializacin, seguida de la sentencia de suma o de incremento. Cuando se haya hecho esto para cada
operacin de suma o conteo particular, se puede ir a la siguiente.
Nota: A partir de este momento todos los problemas ejemplos no tendrn el Anlisis, ni el Diseo
(queda a cargo del lector).
Ejemplos.
Problema: Ingresar una serie de nmeros enteros y mostrar la sumatoria de los pares y la sumatoria de
los impares.
Carreras: Analista de Sistemas y Licenciatura en Sistemas
Asignatura: Resolucin de Problemas y Algoritmos
Docente: Lic. Vernica L. Vanoli
Apunte de Ctedra
- Pgina 36 de 165 -
{
escribir Ingrese la cantidad de elementos de la serie
leer CANTIDAD
CONTADOR 1
SUMAPAR 0
SUMAIMPAR 0
mientras (CONTADOR <= CANTIDAD)
{
escribir Ingrese un nmero entero
leer NUMERO
si (NUMERO % 2 = = 0)
SUMAPAR SUMAPAR + NUMERO
sino
SUMAIMPAR SUMAIMPAR + NUMERO
CONTADOR CONTADOR + 1
}
escribir La sumatoria de los nmeros pares es: , SUMAPAR
escribir La sumatoria de los nmeros impares es: , SUMAIMPAR
}
Otra forma de resolver el problema sera:
{
escribir Ingrese la letra para cargar elementos
leer CONTINUA
SUMAPAR 0
SUMAIMPAR 0
mientras (CONTINUA = = S)
{
escribir Ingrese un nmero entero
leer NUMERO
si (NUMERO % 2 = = 0)
SUMAPAR SUMAPAR + NUMERO
sino
SUMAIMPAR SUMAIMPAR + NUMERO
escribir Contina cargando elementos? (s/n)
leer CONTINUA
}
escribir La sumatoria de los nmeros pares es: , SUMAPAR
escribir La sumatoria de los nmeros impares es: , SUMAIMPAR
}
Problema: Ingresar una serie de caracteres y contar la cantidad de letras A que aparecen. Termina la
serie cuando se ingresa un *.
{
escribir Ingrese un caracter (con * termina)
leer LETRA
CANTIDAD 0
Carreras: Analista de Sistemas y Licenciatura en Sistemas
Asignatura: Resolucin de Problemas y Algoritmos
Docente: Lic. Vernica L. Vanoli
Apunte de Ctedra
- Pgina 37 de 165 -
mientras (LETRA != *)
{
si (LETRA = = A | LETRA = = a)
CANTIDAD CANTIDAD + 1
escribir Ingrese otro caracter (recuerde, con * termina)
leer LETRA
}
escribir La cantidad de letras A ingresadas es: , CANTIDAD
}
Estructura HACER-MIENTRAS
El bucle HACER-MIENTRAS es similar al MIENTRAS, con la diferencia que la condicin
(expresin booleana) se evala al final del bucle (en lugar del principio). Sin embargo, un bucle
HACER-MIENTRAS al contrario de un MIENTRAS, se ejecuta siempre al menos una vez.
Formato general:
hacer
enunciado1
mientras (condicin)
El segmento significa hacer el enunciado MIENTRAS que la condicin sea verdadera.
Veamos un ejemplo de dos segmentos de cdigo que realizan lo mismo usando las dos estructuras.
CONT 1 CONT 1
hacer mientras (CONT <= 5)
{ {
escribir CONT escribir CONT
CONT CONT + 1 CONT CONT + 1
} }
mientras (CONT <= 5)
Debido a que la sentencia MIENTRAS compara la condicin del bucle antes de ejecutar el cuerpo del
mismo, se llama un bucle pretest, la sentencia HACER-MIENTRAS hace lo contrario, por lo tanto, es
conocida como un bucle postest.
HACER-MIENTRAS puede utilizarse para implementar un bucle controlado por contador si sabemos
de antemano que el bucle siempre se ejecutar al menos una vez.
Ejemplos.
Problema: Hallar la sumatoria de los nmeros enteros pares comprendidos entre 1 y 100.
{
SUMA 0
NUMERO 1
hacer
{
si (NUMERO % 2 = = 0)
SUMA SUMA + NUMERO
NUMERO NUMERO + 1
Carreras: Analista de Sistemas y Licenciatura en Sistemas
Asignatura: Resolucin de Problemas y Algoritmos
Docente: Lic. Vernica L. Vanoli
Apunte de Ctedra
- Pgina 38 de 165 -
}
mientras (NUMERO <= 100)
escribir La suma de los nmeros pares de 1 a 100 es: , SUMA
}
Otra forma de solucionar este problema sera:
{
SUMA 0
NUMERO 2
hacer
{
SUMA SUMA + NUMERO
NUMERO NUMERO + 2
}
mientras (NUMERO <= 100)
escribir La suma de los primeros 100 pares es: , SUMA
}
Problema: Ingresar una serie de caracteres y contar la cantidad de letras A que aparecen. Termina la
serie cuando se ingresa un *. Una variante del ejercicio visto anteriormente con MIENTRAS.
Compare los resultados.
{
CANTIDAD 0
hacer
{
escribir Ingrese un caracter (con * termina)
leer LETRA
si (LETRA = = A | LETRA = = a)
CANTIDAD CANTIDAD + 1
}
mientras (LETRA != *)
escribir La cantidad de letras A ingresadas es: , CANTIDAD
}
Estructura PARA
El bucle PARA repite las sentencias (enunciados) de su interior un nmero fijo de veces, previamente
establecido. No necesita una condicin, el bucle PARA inicializa el valor de una variable e incrementa
o decrementa internamente su valor hasta llegar al valor final. Esta estructura se utiliza cuando el o los
enunciados necesitan un nmero especfico de repeticiones y no requieren comprobacin intermedia
de ninguna condicin.
Formato general:
para (valor_inicial; condicin_de_fin; incremento)
enunciado1
para (valor_inicial; condicin_de_fin; decremento)
enunciado1
Carreras: Analista de Sistemas y Licenciatura en Sistemas
Asignatura: Resolucin de Problemas y Algoritmos
Docente: Lic. Vernica L. Vanoli
Apunte de Ctedra
- Pgina 39 de 165 -
Por ejemplo:
para (CONT 1; CONT <= 100; CONT CONT + 1)
escribir CONT
En este caso CONT incrementar de uno en uno, comenzado con el valor 1 hasta obtener el valor 100.
El bucle PARA se ejecutar siempre que la condicin final sea verdadera. Si utilizaremos la sentencia
MIENTRAS, esto se escribira:
CONT 1
mientras (CONT <= 100)
{
escribir CONT
CONT CONT + 1
}
Tambin puede utilizarse un bucle PARA que decremente, por ejemplo:
para (CONT 100; CONT >= 1; CONT CONT - 1)
escribir CONT
En este caso CONT decrementa de uno en uno, comenzado con el valor 100 hasta llegar al valor 1.
Como vemos la sentencia PARA simplifica la escritura de bucles controlados por contador. Pero
debemos tener cuidado, estos bucles no son de propsito general, estn diseados exclusivamente
como bucles controlados por contador. Para utilizarlos inteligentemente se deben conocer y recordar
los siguientes hechos acerca de un bucle PARA:
1. La variable de control del bucle (VCB) no puede cambiarse desde dentro del bucle. Su valor puede
utilizarse, pero no cambiarse. Esto es, la VCB puede aparecer en una expresin pero no en la parte
izquierda de una sentencia de asignacin.
2. La VCB se incrementa o decrementa automticamente, de acuerdo al incremento o decremento
establecido.
3. La VCB queda indefinida al final del bucle. Por lo tanto, no se recomienda utilizar la VCB en una
expresin luego de ejecutado el bucle.
4. El bucle se ejecuta con la VCB en su valor inicial, todos los valores intermedios y el valor final. Si
el valor inicial es mayor que el valor final (en el caso de un incremento) o el valor inicial es menor
que el valor final (en el caso de un decremento), la sentencia PARA no se ejecuta ninguna vez.
Inclusive, la cantidad de veces que se ejecute el bucle (0, 1, 2, ... de veces) depender tambin de
la condicin de fin.
5. No se puede poner una condicin de terminacin adicional en el bucle. La cabecera debe ser
exactamente como el formato general lo indic anteriormente. La variable es el nombre de la
variable de control de bucle, y el valor inicial y la condicin de fin pueden ser cualquier expresin
valida (variables y/o constantes, y operadores).
Ejemplos.
Problema: Mostrar la tabla de conversin de grados Celsius a grados Fahrenheit para temperaturas que
comienzan en -5 C y terminan en 5 C. (1 F: 9/5 x C + 32)
Carreras: Analista de Sistemas y Licenciatura en Sistemas
Asignatura: Resolucin de Problemas y Algoritmos
Docente: Lic. Vernica L. Vanoli
Apunte de Ctedra
- Pgina 40 de 165 -
{
para (CELSIUS 5; CELSIUS <= 5; CELSIUS CELSIUS + 1)
{
FAHRENHEIT 9/5 * CELSIUS + 32
escribir La temperatura Celsius: , CELSIUS, equivale a Fahrenheit: , FAHRENHEIT
}
}
Problema: Mostrar la tabla de conversin de grados Celsius a grados Fahrenheit para temperaturas que
comienzan en 5 C y terminan en -5 C. (1 F: 9/5 x C + 32)
{
para (CELSIUS 5; CELSIUS >= -5; CELSIUS CELSIUS - 1)
{
FAHRENHEIT 9/5 * CELSIUS + 32
escribir La temperatura Celsius: , CELSIUS, equivale a Fahrenheit: , FAHRENHEIT
}
}
Ambos algoritmos hacen lo mismo, slo que el primero muestra la tabla en forma ascendente y el
segundo muestra la tabla en forma descendente.
Criterios para la eleccin de una sentencia iterativa
1. Si el bucle es un bucle controlado por contador simple, utilizar una sentencia PARA. Si el bucle
est controlado por suceso, entonces el bucle PARA no es apropiado. Utilizar en su lugar un bucle
MIENTRAS o HACER-MIENTRAS.
2. Si el bucle es un bucle controlado por suceso y el cuerpo del bucle siempre se ejecuta al menos
una vez, es apropiado utilizar la sentencia HACER-MIENTRAS.
3. Si el bucle es un bucle controlado por suceso y no se sabe nada acerca de la primera ejecucin,
utilizar la sentencia MIENTRAS.
4. Si son apropiados los dos bucles MIENTRAS y HACER-MIENTRAS, utilizar el que mejor refleje
la semntica del bucle. Esto es, si el problema se ha establecido en trminos de cundo continuar
la iteracin, utilizar una sentencia MIENTRAS. Si el problema se ha establecido en trminos de
cuando parar una iteracin, utilizar una sentencia HACER-MIENTRAS.
5. Cuando haya duda, utilizar una sentencia MIENTRAS.
Bucles Anidados
Supongamos que un problema requiere calcular la sumatoria de los sueldos que una empresa debe
pagar a sus empleados en un mes.
El algoritmo para dicho problema sera:
{
escribir Ingrese la cantidad de empleados
leer CANTIDAD
CONT 1
SUMA 0
mientras (CONT <= CANTIDAD)
{
escribir Ingrese un sueldo
Carreras: Analista de Sistemas y Licenciatura en Sistemas
Asignatura: Resolucin de Problemas y Algoritmos
Docente: Lic. Vernica L. Vanoli
Apunte de Ctedra
- Pgina 41 de 165 -
leer SUELDO
SUMA SUMA + SUELDO
CONT CONT + 1
}
escribir La sumatoria de los sueldos es: , SUMA
}
Supongamos que el problema se extiende y nos solicitan calcular la sumatoria de los sueldos de los
empleados de la empresa de todo el ao, teniendo en cuenta que la cantidad de empleados cada mes
puede ser diferente al igual que los importes de los sueldos. Bsicamente el algoritmo ser el mismo,
slo que el proceso debe repetirse 12 veces, ya que se solicita para todo el ao.
{
MES 1
SUMATOTAL 0
mientras (MES <= 12)
{
escribir Ingrese la cantidad de empleados del mes: , MES
leer CANTIDAD
CONT 1
SUMA 0
mientras (CONT <= CANTIDAD)
{
escribir Ingrese un sueldo
leer SUELDO
SUMA SUMA + SUELDO
CONT CONT + 1
}
SUMATOTAL SUMATOTAL + SUMA
MES MES + 1
}
escribir La sumatoria anual de los sueldos es: , SUMATOTAL
}
Esto es lo que se denomina bucle anidado, es decir, que un bucle incluya en su cuerpo a otro bucle.
Para disear una estructura iterativa anidada, comenzamos diseando el bucle ms exterior como de
costumbre. Cuando llegamos al momento en el que es necesario disear el proceso que se repite, el
bucle ms exterior incluir el bucle anidado. Podemos entonces disear el bucle anidado al igual que
haramos con cualquier otro bucle. Este proceso puede ser repetido para cualquier nmero de niveles
de anidamiento.
Identacin
El propsito de identar las sentencias de un programa es dar ayudas visuales al lector y hacer al
programa ms fcil de corregir. Cuando un programa est adecuadamente identado, la forma en que se
agrupan las sentencias es obvia inmediatamente.
Comparemos los siguientes fragmentos:
Carreras: Analista de Sistemas y Licenciatura en Sistemas
Asignatura: Resolucin de Problemas y Algoritmos
Docente: Lic. Vernica L. Vanoli
Apunte de Ctedra
- Pgina 42 de 165 -
mientras (CONT <= 10)
{
leer NUM
si (NUM = = 0)
{
CONT CONT + 1
NUM 1
}
escribir NUM
escribir CONT
}
mientras (CONT <= 10)
{
leer NUM
si (NUM = = 0)
{
CONT CONT + 1
NUM 1
}
escribir NUM
escribir CONT
}
Como regla bsica hemos de dejar algunos espacios (tabulaciones) como identacin, para delimitar los
grupos de sentencias, a efectos de que sea ms clara su identificacin visual.
Importancia de las llaves ({, })
Observemos el siguiente ejemplo:
si (condicion1)
enunciado1
sino
enunciado2
enunciado3
Sabemos que si condicion1 es verdadera se ejecutar el enunciado1, caso contrario se ejecutar el
enunciado2, y en ambos casos luego (o en ltima instancia) se ejecutar el enunciado3.
Supongamos ahora lo siguiente:
si (condicion1)
enunciado1
sino
enunciado2
enunciado3
enunciado4
En este caso, segn como est identado, creemos que si condicion1 es verdadera se ejecutar el
enunciado1 y luego el enunciado4. Lo cual no es cierto. De la manera en que se encuentra escrito, si la
condicion1 resulta ser verdadera se ejecutar el enunciado1, luego el enunciado3 y por ltimo, el
enunciado4.
Cuando necesitamos que de la rama SI o SINO se ejecuten ms de un enunciado, es decir, un conjunto
de enunciados (bloque), no nos tenemos que olvidar de abarcarlos o encerrarlos entre llaves ({, }), de
esa manera logramos que se ejecute el bloque en completo.
El ejemplo anterior bien escrito sera:
Carreras: Analista de Sistemas y Licenciatura en Sistemas
Asignatura: Resolucin de Problemas y Algoritmos
Docente: Lic. Vernica L. Vanoli
Apunte de Ctedra
- Pgina 43 de 165 -
si (condicion1)
enunciado1
sino
{
enunciado2
enunciado3
}
enunciado4
De esta manera, queda bien claro, que el enunciado3 corresponde a la rama sino, ya que la identacin
no siempre es clara y suficiente. Hay que tener en cuenta que la identacin se aplica a la esttica y no
al funcionamiento del programa.
Otro ejemplo con la estructura SI:
si (condicion1)
enunciado1
enunciado2
enunciado3
En este caso, cuando condicion1 sea falsa se ejecutar enunciado2 y luego enunciado3. Para que esto
no ocurra, debemos escribir:
si (condicion1)
{
enunciado1
enunciado2
}
enunciado3
De esta manera, cuando condicion1 sea falsa, slo se ejecutar enunciado3.
Tambin puede ocurrir con la estructura MIENTRAS:
mientras (condicion1) mientras (condicion1)
enunciado1 enunciado1
enunciado2 es igual enunciado2
enunciado3 enunciado3
Aparentemente estos fragmentos de cdigo son distintos pero en realidad hacen lo mismo ya que el
alcance de la iteracin es de un enunciado. Para que tome ms de un enunciado debemos encerrarlo
entre llaves.
mientras (condicion1)
{
enunciado1
enunciado2
enunciado3
}
Carreras: Analista de Sistemas y Licenciatura en Sistemas
Asignatura: Resolucin de Problemas y Algoritmos
Docente: Lic. Vernica L. Vanoli
Apunte de Ctedra
- Pgina 44 de 165 -
Exactamente lo mismo puede ocurrir con la estructura PARA:
para (...) para (...)
enunciado1 enunciado1
enunciado2 es igual enunciado2
enunciado3 enunciado3
En estos ejemplos, enunciado1 es el nico enunciado que se itera, al salir del bucle PARA se ejecutar
una vez los otros enunciados. La forma correcta es:
para (...)
{
enunciado1
enunciado2
enunciado3
}
Tambin se puede hacer lo mismo con la estructura HACER-MIENTRAS.
Carreras: Analista de Sistemas y Licenciatura en Sistemas
Asignatura: Resolucin de Problemas y Algoritmos
Docente: Lic. Vernica L. Vanoli
Apunte de Ctedra
- Pgina 45 de 165 -
ESTRUCTURA GENERAL DE UN PROGRAMA
Concepto de Programa
Un programa de computadora es un conjunto de instrucciones - rdenes dadas a la mquina - que
producirn la ejecucin de una determinada tarea. En esencia, un programa es un medio para
conseguir un fin.
El proceso de programacin es, por consiguiente, un proceso de solucin de problemas y el desarrollo
de un programa requiere de las siguientes fases:
1.- Definicin y Anlisis del problema.
2.- Diseo de algoritmos.
3.- Codificacin del programa.
4.- Pruebas del programa.
5.- Depuracin y Verificacin del programa.
6.- Documentacin.
7.- Mantenimiento.
Partes Constitutivas de un Programa
Tras la decisin de desarrollar un programa, el programador debe establecer el conjunto de
especificaciones que debe contener el programa: entrada, salida y algoritmos de resolucin, que
incluirn las tcnicas para obtener las salidas a partir de las entradas.
Entrada
Programa
(algoritmo de
resolucin)
Salida
El algoritmo de resolucin o caja negra, en realidad, es el conjunto de cdigos que transforman las
entradas del programa (datos) en salidas (resultados).
El programador debe establecer de dnde provienen las entradas al programa. Las entradas, en
cualquier caso, procedern de dispositivos perifricos de entrada (teclado, mouse, disco, etc.). El
proceso de introducir la informacin de entrada (datos) en la memoria de la computadora se denomina
entrada de datos, operacin de lectura o accin de LEER.
Las salidas de datos se deben presentar en dispositivos perifricos de salida (pantalla, impresora,
discos, etc.). La operacin de salida de datos se conoce tambin como escritura o accin de
ESCRIBIR.
Elementos Bsicos de un Programa
Los lenguajes de programacin tienen elementos bsicos que se utilizan como bloques constructivos,
as como reglas para las que esos elementos se combinan. Estas reglas se denominan sintaxis del
lenguaje. Solamente las instrucciones sintcticamente correctas pueden ser interpretadas por la
computadora y los programas que contengan errores de sintaxis son rechazadas por la mquina.
Los elementos bsicos constitutivos de un programa o algoritmo son:
1. Palabras Reservadas (leer, escribir, si-sino, mientras, etc.).
2. Identificadores (nombres de variables, constantes, etc.).
3. Operadores.
Carreras: Analista de Sistemas y Licenciatura en Sistemas
Asignatura: Resolucin de Problemas y Algoritmos
Docente: Lic. Vernica L. Vanoli
Apunte de Ctedra
- Pgina 46 de 165 -
Estructura General de un Programa en Pseudocdigo
Formato general:
principal nombre_del_programa
{
declaracin_de_constantes_y_variables
...
cuerpo_del_programa
...
}
Declaracin de constantes y variables
Antes de poder utilizarse constantes y/o variables en un programa, se las debe declarar en memoria.
Ya que ambas no son ms que posiciones en memoria y por eso, se debe reservar el lugar que se
necesita para manipular el contenido de las mismas.
Formato general:
nombre_de_la_constante = valor
tipo_de_la_variable nombre_de_la_variable
Por ejemplo:
CANTDIAS = 30
PI =
entero NUMERO
caracter LETRA
Ejemplos.
Problema: Suponemos que ya hicimos el anlisis y diseo del algoritmo y ahora lo convertimos en un
programa. Realizar la suma de diez nmeros ingresados por pantalla.
principal SumoNumeros
{ //principal
//declaracin de constantes y variables
CANT=10 //cantidad de nmeros
real NRO //nmeros ingresados
entero I //contador de la cantidad de nmeros ingresados
entero SUM //acumulador de la suma de los nmeros
//inicializacin de variables
I 0
SUM 0
//inicio del algoritmo
mientras (I < CANT)
{ //mientras
escribir Ingrese un nmero
leer NRO
Carreras: Analista de Sistemas y Licenciatura en Sistemas
Asignatura: Resolucin de Problemas y Algoritmos
Docente: Lic. Vernica L. Vanoli
Apunte de Ctedra
- Pgina 47 de 165 -
SUM SUM + NRO
I I + 1
} //mientras
//muestra del resultado
escribir La suma de los , CANT, nmeros ingresados es: , SUM
} //principal
Nota: El texto que se encuentra inicializado con doble barra (//), representa a comentarios y sirve para
describir o documentar ciertas partes del programa. Siempre son de mucha utilidad, ya que informan
brevemente lo que est escrito. Y no tienen ningn efecto sobre la ejecucin del programa.
Problema: calcular la sumatoria de los sueldos de los empleados de una empresa de todo el ao,
teniendo en cuenta que la cantidad de empleados cada mes puede ser diferente al igual que los
importes de los sueldos.
principal Sueldos
{ //principal
//declaracin de constantes y variables
ULTMES = 12
entero MES, CANTIDAD, CONT
real SUMATOTAL, SUMA, SUELDO
//inicializacin de variables
MES 1
SUMATOTAL 0
//inicio del algoritmo
mientras (MES <= ULTMES)
{ //mientras de meses
escribir Ingrese la cantidad de empleados del mes: , MES
leer CANTIDAD
CONT 1
SUMA 0
mientras (CONT <= CANTIDAD)
{ //mientras de empleados
escribir Ingrese un sueldo
leer SUELDO
SUMA SUMA + SUELDO
CONT CONT + 1
} //mientras de empleados
SUMATOTAL SUMATOTAL + SUMA
MES MES + 1
} //mientras de meses
//muestra del resultado
escribir La sumatoria anual de los sueldos es: , SUMATOTAL
} //principal
Carreras: Analista de Sistemas y Licenciatura en Sistemas
Asignatura: Resolucin de Problemas y Algoritmos
Docente: Lic. Vernica L. Vanoli
Apunte de Ctedra
- Pgina 48 de 165 -
Uso de variables
Una variable antes de ser utilizada (Lectura, Escritura o Asignacin) debe ser declarada. Esto
significa que debe darse a conocer el tipo de dato al que corresponde.
Por ejemplo:
principal PotenciaCuadrada
{
POT NUM ^ 2
escribir El cuadrado de , NUM, es: , POT
}
principal PotenciaCuadrada
{
entero NUM, POT
POT NUM ^ 2
escribir El cuadrado de , NUM, es: , POT
}
Como vemos, en el primer caso se usaron las variables NUM y POT, sin previa declaracin. Lo cual
es un error para el programa. La solucin se encuentra en el segundo caso, dnde las variables se
declararon previamente. Pero el algoritmo no est completo:
Antes de utilizar una variable a la derecha de una operacin de asignacin u operacin de escritura,
la misma debe inicializarse mediante una operacin de asignacin u operacin de lectura.
Por ejemplo:
principal PotenciaCuadrada
{
entero NUM, POT
POT NUM ^ 2
escribir El cuadrado de , NUM, es: , POT
}
principal PotenciaCuadrada
{
entero NUM, POT
leer NUM
POT NUM ^ 2
escribir El cuadrado de , NUM, es: , POT
}
Como vemos, el primer caso es incorrecto, puesto que para calcular POT es necesario que la variable
NUM tenga algn valor, es decir, previo al clculo, la variable no ha sido inicializada. Caso contrario
ocurre en el segundo caso, dnde la variable NUM, obtiene un valor a partir de la operacin de lectura.
Pruebas del programa
Existen muchas tcnicas para probar programas, que no se estudiaran en esta materia, pero s es
necesario comprobar de alguna manera el programa que se ha construido. Por el momento se utilizar
lo que se conoce como Prueba de Escritorio o Traza. Consiste en hacer un seguimiento de las
variables que estn en juego en el programa, e ir determinando si el resultado de las mismas
corresponde o no al objetivo del programa. La manera de representarlo es totalmente a eleccin del
programador, por medio de una tabla, casilleros, etc. Es una manera efectiva de corroborar el
funcionamiento del programa, desde ya que una traza bien hecha influye un 100% en determinar si el
programa funciona o no.
Carreras: Analista de Sistemas y Licenciatura en Sistemas
Asignatura: Resolucin de Problemas y Algoritmos
Docente: Lic. Vernica L. Vanoli
Apunte de Ctedra
- Pgina 49 de 165 -
ARREGLOS
Hasta ahora hemos visto datos de tipo simple: entero, real, caracter y booleano. Todos estos datos de
tipo simple tienen una caracterstica comn, que cada variable representa un dato individual.
Los datos de tipo compuestos u objetos son arreglos, cadenas, archivos, pilas, colas, listas, rboles,
etc. Todos ellos tienen una caracterstica en comn: un nico identificador puede representar a
mltiples datos individuales, pudiendo cada uno de stos ser referenciado separadamente. As, los
datos de tipo compuesto pueden ser manipulados colectiva o individualmente, dependiendo de las
necesidades de cada aplicacin particular.
Un arreglo es un conjunto finito, ordenado e indexado de elementos con las siguientes caractersticas:
todos los elementos son del mismo tipo, esto hace que sea un tipo de dato homogneo;
los elementos pueden recuperarse en cualquier orden, simplemente indicando la posicin que
ocupa dentro de la estructura, por este motivo es una estructura indexada;
la memoria ocupada a lo largo de la ejecucin del programa es fija, por esto es una estructura de
datos esttica.
Existen varios tipos de arreglos (de acuerdo a su dimensin), en esta materia se estudiarn:
Arreglos Unidimensionales (Vectores).
Arreglos Bidimensionales (Matrices).
Arreglos Unidimensionales: Vectores
El tipo ms simple de arreglo es el arreglo unidimensional o arreglo lineal o vector (arreglo de una
dimensin). El subndice o ndice de un elemento [0, 1, 2, ..., n-1] designa su posicin en la ordenacin
del vector.
Grficamente, se puede representar de la siguiente forma:
elemento 1 elemento 2 elemento 3 ... elemento n-1 elemento n
posicin 0 posicin 1 posicin 2 ... posicin n-2 posicin n-1
En un vector, la manera de hacer referencia a alguno de sus elementos es a travs del nombre del
arreglo y la posicin del elemento (ndice), de la forma:
nombre_del_vector[nmero_de_posicin]
Por ejemplo: LISTA es el nombre de un arreglo que contiene 10 nmeros enteros.
3 -2 1 10 2 5 1 6 7 -8
LISTA[0] LISTA[1] LISTA[2] LISTA[3] LISTA[4] LISTA[5] LISTA[6] LISTA[7] LISTA[8] LISTA[9]
Esto significa que en la primer posicin (0) de LISTA se halla almacenado el valor 3, en la segunda
posicin el valor -2, en la tercera posicin el valor 1, y en la novena posicin el valor -8.
Entonces, el elemento de cada posicin se obtiene de la siguiente manera:
Carreras: Analista de Sistemas y Licenciatura en Sistemas
Asignatura: Resolucin de Problemas y Algoritmos
Docente: Lic. Vernica L. Vanoli
Apunte de Ctedra
- Pgina 50 de 165 -
LISTA[0]: 3
LISTA[1]: -2
LISTA[2]: 1
LISTA[3]: 10
LISTA[4]: 2
LISTA[5]: 5
LISTA[6]: 1
LISTA[7]: 6
LISTA[8]: 7
LISTA[9]: -8
Declaracin y creacin de un arreglo unidimensional (Vector)
Formato general:
Declaracin:
tipo_de_dato [ ] nombre_del_vector
Creacin:
nombre_del_vector = nuevo tipo_de_dato[dimensin_del_vector]
Por ejemplo:
entero [ ] LISTA real [ ] VECTOR
LISTA = nuevo entero[10] VECTOR = nuevo real[25]
En estos ejemplos hemos definido a la variable LISTA como un arreglo de 10 elementos enteros y a
VECTOR como un arreglo de 25 elementos reales. Otra forma de declarar un vector, es por medio de
constantes:
TOPE = 100
entero [ ] VECTOR
VECTOR = nuevo entero[TOPE]
ndices (posicin o subndice)
El ndice de un arreglo es el valor que nos permite diferenciar los distintos elementos individuales del
mismo. Como ya hemos visto el ndice se indica entre corchetes luego del nombre de la variable del
vector: VECTOR[1] o LISTA[5] (los ndices son 1 y 5 respectivamente).
La primera posicin de un vector siempre es 0. Por lo tanto, si el vector se ha declarado de dimensin
100, los ndices estn comprendidos entre 0 y 99. Si se hace una referencia a un valor mayor que 99,
se produce un error en el programa.
En general, el ndice puede ser una constante, una variable o una expresin aritmtica. Si el ndice es
una expresin aritmtica sta se evaluar a efectos de obtener el valor del ndice.
Veamos el siguiente ejemplo, segn el vector LISTA (anteriormente mencionado) y la variable I cuyo
valor es 5, podemos hacer las siguientes referencias:
LISTA[I] Se refiere al 6to. elemento de LISTA cuyo valor es 5.
LISTA[I + 2] Se refiere al 8vo. elemento de LISTA cuyo valor es 8.
LISTA[I - 1] Se refiere al 5to. elemento de LISTA cuyo valor es 2.
LISTA[I / 2] Se refiere al 3ro. elemento de LISTA cuyo valor es 1.
Todas estas referencias son vlidas. Pero si hacemos: LISTA[I * 3], nos da un ndice igual a 15, lo
cual no es vlido puesto que LISTA no posee un elemento LISTA[15]. Lo mismo ocurre si hacemos
Carreras: Analista de Sistemas y Licenciatura en Sistemas
Asignatura: Resolucin de Problemas y Algoritmos
Docente: Lic. Vernica L. Vanoli
Apunte de Ctedra
- Pgina 51 de 165 -
LISTA[I - 10], nos da un ndice igual a -5, tampoco es vlido, ya que LISTA no posee posiciones
negativas.
Manejo de vectores
Una vez que hemos definido el vector, debemos guardar informacin en l, puesto que al principio el
vector esta vaco o con basura. Hay varias formas de almacenar informacin en un vector. En este
caso, veremos la carga para un vector.
1. A travs de la asignacin de datos:
LISTA[0] 3
LISTA[1] -2
LISTA[2] 1
LISTA[3] 10
LISTA[4] 2
LISTA[5] 5
LISTA[6] 1
LISTA[7] 6
LISTA[8] 7
LISTA[9] -8
Estamos asignando valores enteros a cada posicin del vector.
2. A travs de la lectura de los datos:
leer LISTA[0]
leer LISTA[1]
leer LISTA[2]
leer LISTA[3]
leer LISTA[4]
leer LISTA[5]
leer LISTA[6]
leer LISTA[7]
leer LISTA[8]
leer LISTA[9]
En este caso la lectura de los datos se almacena directamente en las distintas posiciones del vector.
Podemos cargar un elemento al vector, algunos o cargar el vector de forma completo. El problema con
esta ltima forma es que si nuestro vector tiene una dimensin grande, por ejemplo 1000 posiciones,
escribir la lectura de cada posicin del vector requiere una extensa cantidad de lneas que hacen lo
mismo. Lo cual es innecesario. Generalmente, para solucionar este problema se utiliza un bucle que
permite realizar la carga de un vector, de forma ms rpida y sencilla.
Veamos:
para (POS 0; POS <10; POS POS + 1)
{
escribir Ingrese un valor en la posicin , POS
leer LISTA[POS]
}
Carreras: Analista de Sistemas y Licenciatura en Sistemas
Asignatura: Resolucin de Problemas y Algoritmos
Docente: Lic. Vernica L. Vanoli
Apunte de Ctedra
- Pgina 52 de 165 -
Donde POS es una variable que sirve para controlar el bucle y como ndice del vector. Al utilizar una
variable como ndice logramos acceder a las distintas posiciones del vector.
De la misma manera que el vector ha sido cargado puede mostrarse uno, alguno o todos los elementos
del mismo.
Veamos:
para (POS 0; POS <10; POS POS + 1)
escribir LISTA[POS]
Tanto la carga como la muestra del vector, son actividades constantes en el uso de los mismos. Pero,
existen otras operaciones que varan de acuerdo al problema a desarrollar. Por ejemplo, una vez
cargado el vector, se puede hallar la suma de sus elementos. En este caso, procedemos de la misma
manera, con un bucle cuya variable contador nos sirve adems como ndice del vector.
Veamos:
SUMA 0
para (POS 0; POS <10; POS POS + 1)
SUMA SUMA + LISTA[POS]
escribir La sumatoria de los elementos del vector es: , SUMA
En este caso, con el bucle vamos recorriendo el vector, accediendo a cada elemento del mismo
mediante el ndice, e incrementado a la variable SUMA.
Ejemplos.
Problema: Calcular la media de las estaturas de una clase de alumnos y deducir cuntos son ms altos
que la media y cuantos ms bajos que dicha media.
principal EstaturasDeLaClase
{ //principal
//declaracin de variables
entero ESTU //nmero de estudiantes de la clase
real [ ] ESTATURAS
ESTATURAS = nuevo real [100] //estatura de los n alumnos
entero CONT //contador de alumnos
real MEDIA //media de estaturas
entero ALTOS //alumnos de estatura mayor que la media
entero BAJOS //alumnos de estatura menor que la media
real SUMA //totalizador de estaturas
//carga de datos
escribir Ingrese la cantidad de estudiantes en la clase
leer ESTU
//operacin de suma
CONT 0
SUMA 0
mientras (CONT < ESTU)
{
Carreras: Analista de Sistemas y Licenciatura en Sistemas
Asignatura: Resolucin de Problemas y Algoritmos
Docente: Lic. Vernica L. Vanoli
Apunte de Ctedra
- Pgina 53 de 165 -
escribir Ingrese la estatura del alumno , CONT
leer ESTATURAS[CONT]
SUMA SUMA + ESTATURAS[CONT]
CONT CONT + 1
}
//calculo de la media
MEDIA SUMA / ESTU
ALTOS 0
BAJOS 0
para (CONT 0; CONT < ESTU; CONT CONT + 1)
{
si (ESTATURAS[CONT] < MEDIA)
BAJOS BAJOS + 1
sino
si (ESTATURAS[CONT] > MEDIA)
ALTOS ALTOS + 1
}
//muestra de resultados
escribir La media de las estaturas es: , MEDIA
escribir La cantidad de alumnos de estatura mayor que la media es de: , ALTOS
escribir La cantidad de alumnos de estatura menor que la media es de: , BAJOS
} //principal
Problema: Generar una lista de enteros, reemplazar los mltiplos de 3 por 3 y mostrar la lista
resultante.
principal MultiplosDeTres
{ //principal
//declaracin de las variables
entero DIM //dimensin de la lista
entero [ ] LISTA
LISTA = nuevo entero[100] //Lista de enteros
entero CONT //contador de bucles
//carga de la dimensin y los datos
escribir Ingrese la cantidad de elementos a cargar
leer DIM
para (CONT 0; CONT < DIM; CONT CONT + 1)
{
escribir Ingrese el elemento, CONT
leer LISTA[CONT]
}
//operacin de mltiplo
CONT 0
hacer
{
Carreras: Analista de Sistemas y Licenciatura en Sistemas
Asignatura: Resolucin de Problemas y Algoritmos
Docente: Lic. Vernica L. Vanoli
Apunte de Ctedra
- Pgina 54 de 165 -
si (LISTA[CONT] % 3 = = 0)
LISTA[CONT] 3
CONT CONT + 1
}
mientras (CONT < DIM)
//muestra de resultados
escribir El vector resultante es
CONT 0
mientras (CONT < DIM)
{
escribir LISTA[CONT]
CONT CONT + 1
}
} //principal
Ntese que en ambos ejemplos, no se us como tamao del vector el valor declarado al principio
(100), sino que se pidi una cantidad y se trabaj con ella. La diferencia est en cunto voy a reservar
de memoria para guardar mi vector y cunto puedo de esa cantidad, usar en realidad. Queda a cargo
del Lector. Tenga en cuenta, qu sucedera si la dimensin ingresada es un valor negativo o mayor que
el valor declarado como tamao real del vector. Busque la solucin para ello.
Recomendacin: cada operacin que se realice con un vector, escribirlo de forma separada. No
mezclar en una misma iteracin la carga, con alguna operacin sobre el vector y la muestra del mismo.
Carreras: Analista de Sistemas y Licenciatura en Sistemas
Asignatura: Resolucin de Problemas y Algoritmos
Docente: Lic. Vernica L. Vanoli
Apunte de Ctedra
- Pgina 55 de 165 -
Operaciones de Ordenacin y de Bsqueda
Las computadoras emplean una gran parte de su tiempo en operaciones de bsqueda y clasificacin de
datos. Las operaciones de clculo numrico, y sobre todo de gestin, requieren normalmente
operaciones de clasificacin de los datos. Por ejemplo, ordenar fichas de clientes por orden alfabtico,
por direcciones o por cdigo postal.
Ordenacin
Existen dos tipos de ordenacin: ordenacin interna (de arreglos), y ordenacin externa (de
archivos). Los arreglos se almacenan en memoria interna o central, de acceso aleatorio y directo, y por
ello su gestin es rpida. Los archivos se sitan en dispositivos de almacenamiento externo que son
ms lentos y basados en dispositivos mecnicos: cintas y discos.
La ordenacin (clasificacin) es una operacin tan frecuente en programas de computadora que gran
cantidad de algoritmos se ha diseado para clasificar listas de elementos con eficacia y rapidez. La
eleccin de un determinado algoritmo depende del tamao del vector a clasificar, el tipo de datos y la
cantidad de memoria disponible.
La ordenacin o clasificacin es un proceso de organizar datos en algn orden o secuencia especfica,
tal como creciente o decreciente para datos numricos o para datos de caracteres, en orden alfabtico.
Los algoritmos de ordenacin se clasifican en directos o bsicos y en avanzados. Estos ltimos son
ms eficientes y ms rpidos pero ms complejos. En cambio los mtodos directos son sencillos,
aunque ineficientes para listas de gran tamao.
Los mtodos directos ms populares son:
Ordenacin por Insercin.
Ordenacin por Seleccin.
Ordenacin por Intercambio (Burbuja).
Ordenacin por Insercin
Este mtodo consiste en insertar un elemento en una parte ya ordenada de este vector y comenzar de
nuevo con los elementos restantes. Por ser utilizado generalmente por los jugadores de cartas se lo
conoce tambin por el nombre de mtodo de la baraja.
El mtodo se basa en comparaciones y desplazamientos sucesivos. El algoritmo de clasificacin de un
vector X para N elementos, se realiza con un recorrido de todo el vector y la insercin del elemento
correspondiente en el lugar adecuado. El recorrido se realiza desde el segundo elemento al n-simo
elemento.
Algoritmo
para (I 1; I < N; I I + I)
{
AUX VECTOR[I]
J I - 1 //apunta al primer elemento a comparar
mientras (J >= 0 & VECTOR[J] > AUX)
{
VECTOR[J + 1] VECTOR[J] //se corre 1 lugar a la derecha
J J - 1
}
VECTOR[J + 1] AUX //inserta el valor auxiliar
}
Carreras: Analista de Sistemas y Licenciatura en Sistemas
Asignatura: Resolucin de Problemas y Algoritmos
Docente: Lic. Vernica L. Vanoli
Apunte de Ctedra
- Pgina 56 de 165 -
Veamos el siguiente ejemplo, aplicando insercin:
22 25 06 20 42 09 03 33
I : 1 22 25 06 20 42 09 03 33
I : 2 06 22 25 20 42 09 03 33
I : 3 06 20 22 25 42 09 03 33
I : 4 06 20 22 25 42 09 03 33
I : 5 06 09 20 22 25 42 03 33
I : 6 03 06 09 20 22 25 42 33
I : 7 03 06 09 20 22 25 33 42
El nmero de movimientos y comparaciones mnimo (mejor caso) se presenta cuando los elementos
estn ordenados inicialmente, el mximo (peor caso) se presenta si estn inicialmente en orden
inverso. Es evidente que el algoritmo no modifica el orden de los elementos con el mismo valor.
Ordenacin por Seleccin
La idea esencial de este mtodo es: si tuviramos en una hoja de papel una columna con 10 nmeros
para ordenar en forma ascendente, probablemente haramos lo siguiente:
1. Buscar el elemento ms pequeo.
2. Escribirlo en el papel en una segunda columna.
3. Tachar el nmero de la lista original.
4. Repetir el proceso, siempre buscando el nmero ms pequeo que queda de la lista original.
5. Parar cuando todos los nmeros hubieran sido tachados de la lista original.
Pero esta idea tiene dos puntos complicados: hablar de una segunda columna implica utilizar un
segundo arreglo, lo cual puede ser crtico (si el arreglo original es muy grande, entonces requiere
mucha memoria - el doble -); tachar una componente de un arreglo es una tarea difcil. Pero estos dos
inconvenientes, tienen solucin haciendo una pequea variacin en la idea original; para no mover las
componentes a un segundo arreglo y tacharlo de la lista original, podemos poner el valor en el lugar
que le corresponda en el arreglo original intercambiando su lugar con la componente que hubiera all.
Finalmente lo que har este mtodo es buscar el elemento de menor valor del vector y colocarlo en la
primera posicin. Luego se busca el segundo elemento ms pequeo y se coloca en la segunda
posicin, y as sucesivamente.
Los pasos sucesivos a dar son:
1.- Seleccionar el elemento menor del vector de n elementos.
2.- Intercambiar dicho elemento con el primero.
3.- Repetir estas operaciones con los n-1 elementos restantes, seleccionando el segundo elemento;
continuar con los n-2 elementos restantes hasta que slo quede el mayor.
Carreras: Analista de Sistemas y Licenciatura en Sistemas
Asignatura: Resolucin de Problemas y Algoritmos
Docente: Lic. Vernica L. Vanoli
Apunte de Ctedra
- Pgina 57 de 165 -
Algoritmo
para (I 0; I < N - 1; I I + 1)
{
//busca el mnimo VECTOR[P] entre VECTOR[I], ..., VECTOR[N]
P I
para (J I + 1; J < N; J J + 1)
si (VECTOR[J] < VECTOR[P])
P J
//intercambia VECTOR[I] y VECTOR[P]
AUX VECTOR[P]
VECTOR[P] VECTOR[I]
VECTOR[I] AUX
//ahora VECTOR[0] <= ... <= VECTOR[I] y adems, VECTOR[I] <= VECTOR[J] con I<J<N
}
Es evidente que el nmero de comparaciones entre los elementos es independiente de la ordenacin
inicial de stos.
En general el algoritmo de seleccin es preferible al de insercin, aunque en los casos en que los
elementos estn inicialmente ordenados o casi ordenados, ste ltimo puede ser algo ms rpido
(mejor caso).
Veamos el siguiente ejemplo aplicando seleccin:
320 96 16 90 120 80 200 64
El mtodo comienza buscando el nmero ms pequeo.
La lista nueva ser:
16 96 320 90 120 80 200 64
A continuacin, se busca el siguiente nmero ms pequeo, 64, y se realizan las operaciones 1 y 2.
La nueva lista sera:
16 64 320 90 120 80 200 96
Si se siguen realizando las iteraciones se encontrarn las siguientes lneas:
16 64 80 90 120 320 200 96
16 64 80 90 120 320 200 96
16 64 80 90 96 320 200 120
16 64 80 90 96 120 200 320
16 64 80 90 96 120 200 320
Carreras: Analista de Sistemas y Licenciatura en Sistemas
Asignatura: Resolucin de Problemas y Algoritmos
Docente: Lic. Vernica L. Vanoli
Apunte de Ctedra
- Pgina 58 de 165 -
Ordenacin por Intercambio
El algoritmo de clasificacin de intercambio o burbuja se basa en el principio de comparar pares de
elementos adyacentes e intercambiarlos entre s hasta que estn todos ordenados.
Los pasos a dar son:
1.- Comparar los elementos del primer y segundo lugar (subndice 0 y 1), si estn en orden, se
mantienen como estn; en caso contrario se intercambian entre s.
2.- A continuacin se comparan los elementos del segundo y tercer lugar (subndice 1 y 2); de nuevo
se intercambian si es necesario.
3.- El proceso contina hasta que cada elemento del vector ha sido comparado con sus elementos
adyacentes y se han realizado los intercambios necesarios.
A este mtodo se lo conoce como burbuja porque el elemento cuyo valor es ms pequeo, sube
posicin a posicin hacia el comienzo de la lista al igual que las burbujas de aire en un depsito o
botella de agua. O podra verse tambin como que el elemento ms grande se arrastra hacia el final del
vector. Cualquier alternativa es vlida. En el segundo recorrido, el segundo elemento ms pequeo
llegar a la segunda posicin, o el segundo elemento ms grande se arrastrar a la penltima posicin
(n - 2), y as sucesivamente.
Algoritmo
para (I N - 1; I >= 1; I I - 1)
//poner el mayor elemento de VECTOR[0], ..., VECTOR[I] en VECTOR[I]
para (J 0; J <= I 1; J J + 1)
si (VECTOR[J] > VECTOR[J + 1])
{ //intercambiar elementos
AUX VECTOR[J]
VECTOR[J] VECTOR[J + 1]
VECTOR[J + 1] AUX
}
//ahora VECTOR[I] <= ... <= VECTOR[N] y VECTOR[J] <= VECTOR[I] con 0<=J<I
Veamos el siguiente ejemplo aplicando burbuja:
72 64 50 23 84 18 37 99 45 08
Se muestran los pasos necesarios de la ordenacin por burbuja:
I : 9 64 50 23 72 18 37 84 45 08 99
I : 8 50 23 64 18 37 72 45 08 84 99
I : 7 23 50 18 37 64 45 08 72 84 99
I : 6 23 18 37 50 45 08 64 72 84 99
I : 5 18 23 37 45 08 50 64 72 84 99
I : 4 18 23 37 08 45 50 64 72 84 99
I : 3 18 23 08 37 45 50 64 72 84 99
Carreras: Analista de Sistemas y Licenciatura en Sistemas
Asignatura: Resolucin de Problemas y Algoritmos
Docente: Lic. Vernica L. Vanoli
Apunte de Ctedra
- Pgina 59 de 165 -
I : 2 18 08 23 37 45 50 64 72 84 99
I : 1 08 18 23 37 45 50 64 72 84 99
Se puede realizar una mejora en la velocidad de ejecucin del algoritmo. Observemos que en el primer
recorrido del vector (cuando I tiene el valor 9) el valor mayor del vector se mueve al ltimo elemento
VECTOR[N - 1]. Por consiguiente, en el prximo paso no es necesario comparar VECTOR[N - 2] y
VECTOR[N - 1]. En otras palabras, el lmite superior del bucle PARA puede ser N - 2. Despus de
cada paso se puede decrementar en uno el lmite superior del bucle PARA.
A pesar de las mejoras que se puedan realizar, la operacin de intercambio de dos elementos
generalmente es mucho ms costosa que una operacin de comparacin. Por lo tanto, la ordenacin
por intercambio es inferior a la ordenacin por insercin o por seleccin.
Bsqueda
La bsqueda es un proceso de ubicar informacin particular en una coleccin de datos. La manera de
buscar la informacin depende de la forma en que los datos de la coleccin se encuentren organizados.
Los mtodos de bsqueda consisten en buscar un dato que tiene una propiedad particular (por ejemplo
una estructura con un componente igual a x) y en caso de encontrarlo, puede retornar afirmativo o
retornar informacin relacionada, por ejemplo: su posicin en la estructura.
Los mtodos ms conocidos son:
Bsqueda Secuencial o Lineal.
Bsqueda Binaria.
Bsqueda Secuencial
El mtodo ms sencillo de buscar un elemento en un vector es explorar secuencialmente el vector, o
dicho en otras palabras, recorrer el vector desde el primer elemento hasta el ltimo, linealmente. Se
compara cada elemento del vector con un valor deseado (elemento a buscar) hasta que se encuentra o
se termina de recorrer el vector completo. Un resultado posible es: si se encuentra el elemento buscado
visualizar un mensaje similar a Elemento encontrado, en caso contrario visualizar un mensaje
similar a Elemento no existente.
Algoritmo
I 0
ENCONTRADO Falso
mientras (ENCONTRADO = = Falso & I < N)
{
si (VECTOR[I] = = BUSCADO)
{
ENCONTRADO Verdadero
POSICION I
}
I I + 1
}
si (ENCONTRADO = = Verdadero)
escribir El elemento buscado se encuentra en la posicin , POSICION
sino
escribir El elemento buscado NO se encuentra en el vector
Carreras: Analista de Sistemas y Licenciatura en Sistemas
Asignatura: Resolucin de Problemas y Algoritmos
Docente: Lic. Vernica L. Vanoli
Apunte de Ctedra
- Pgina 60 de 165 -
El mejor caso en una bsqueda secuencial es cuando el elemento buscado se encuentra en la primera
posicin y el peor caso es cuando el elemento buscado no se encuentra en el vector o se encuentra en
la ltima posicin (es decir, es el ltimo elemento). Aunque ste puede ser un mtodo adecuado para
pocos datos, se necesita una tcnica ms eficaz para conjuntos grandes de datos. Si el nmero de
elementos en el vector es grande, el algoritmo se hace muy lento en tiempo, de un modo considerable.
Por ende, la bsqueda secuencial o lineal no es el mtodo ms eficiente para vectores con un gran
nmero de elementos.
Bsqueda Binaria
Para mejorar el tiempo de la bsqueda lineal, existe el mtodo de bsqueda binaria, que accede al
vector en mitades. Por ejemplo, si tuviramos que consultar un abonado en la gua telefnica,
normalmente no buscamos el nombre en orden secuencial, sino que buscamos en la primera o segunda
mitad de la gua; una vez escogida esa mitad, volvemos a tantear una de sus dos submitades, y as
sucesivamente repetimos el proceso hasta que se localiza la pgina correcta, con el nombre buscado.
Naturalmente, las personas que realizan este tipo de bsquedas nunca utilizaran un mtodo de
bsqueda secuencial, sino un mtodo que se basa en la divisin sucesiva del espacio ocupado por el
vector en sucesivas mitades, hasta encontrar el elemento buscado. La bsqueda binaria utiliza el
mtodo de divide y vencers, para localizar el valor deseado. Con este mtodo se examina primero
el elemento central de la lista; si ste es el elemento buscado, entonces la bsqueda ha terminado. En
caso contrario, se determina si el elemento buscado est en la primera o en la segunda mitad de la lista
y a continuacin se repite este proceso, utilizando el elemento central de esa sublista. Para poder
realizar esta operacin la bsqueda binaria necesita como precondicin que los elementos se
encuentren clasificados en un determinado orden, caso contrario, no se podr aplicar el mtodo
mencionado.
Algoritmo
ENCONTRADO Falso
PRIMERO 0 //lmite inferior del intervalo de bsqueda
ULTIMO N - 1 //lmite superior del intervalo de bsqueda
mientras (PRIMERO <= ULTIMO & ENCONTRADO = = Falso)
{
//lmite central del intervalo de bsqueda
PTOMEDIO (PRIMERO + ULTIMO) / 2
si (VECTOR[PTOMEDIO] = = BUSCADO)
ENCONTRADO Verdadero
sino
si (VECTOR[PTOMEDIO] > BUSCADO)
ULTIMO PTOMEDIO - 1
sino
PRIMERO PTOMEDIO + 1
}
si (ENCONTRADO = = Verdadero)
escribir El elemento buscado se encuentra en la posicin , PTOMEDIO
sino
escribir El elemento buscado NO se encuentra en el vector
Carreras: Analista de Sistemas y Licenciatura en Sistemas
Asignatura: Resolucin de Problemas y Algoritmos
Docente: Lic. Vernica L. Vanoli
Apunte de Ctedra
- Pgina 61 de 165 -
Supongamos que se tiene la siguiente lista de elementos:
1 3 5 14 92 98 983 2005 2446 2685 3200
|--------------primera sublista--------------| |--------------segunda sublista-------------|
Si se est buscando el elemento 983, se examina el nmero central 98 en la quinta posicin. Y como
983 es mayor que 98, se desprecia la primera sublista y nos centramos en la segunda:
1 3 5 14 92 98 983 2005 2446 2685 3200
|--1 sublista--| |--2 sublista--|
El nmero central de esa sublista es 2446 y el elemento buscado es 983, por ende, es menor que 2446;
entonces se elimina (se desprecia) la segunda sublista y nos queda:
1 3 5 14 92 98 983 2005 2446 2685 3200
|-------------|
Como no hay elemento central, elegimos el trmino inmediatamente anterior al trmino central, 983,
que es el buscado. Se han necesitado tres comparaciones, mientras que la bsqueda secuencial hubiese
necesitado siete.
La bsqueda binaria se utiliza en vectores ordenados (orden creciente si los datos son numricos y
orden alfabticamente si son caracteres) y se basa en la constante divisin del espacio de bsqueda
(acceso del vector). Como se ha comentado, se comienza comparando el elemento que se busca, no
con el primer elemento, sino con el elemento central. Si el elemento buscado (x) es menor que el
elemento central, entonces x deber estar en la mitad izquierda o inferior del vector; si es mayor que el
valor central, deber estar en la mitad derecha o superior, y si es igual al valor central, se habr
encontrado el elemento buscado.
Si el elemento buscado se encuentra en la posicin central en la primera vuelta, estamos en presencia
del mejor caso. Y si el elemento no se encuentra o se encuentra en la ltima sublista generada se
presenta el peor caso.
Carreras: Analista de Sistemas y Licenciatura en Sistemas
Asignatura: Resolucin de Problemas y Algoritmos
Docente: Lic. Vernica L. Vanoli
Apunte de Ctedra
- Pgina 62 de 165 -
Arreglos Bidimensionales: Matrices
El arreglo bidimensional se puede considerar como un arreglo con dos dimensiones o dos ndices. O
tambin se puede considerar como un vector de vectores, o sea que por cada componente del vector es
otro vector.
Es, por consiguiente, un conjunto de elementos, todos del mismo tipo, en el cul el orden de los
componentes es significativo y en el que se necesitan especificar dos subndices para poder identificar
a cada elemento de la matriz.
En una matriz, hacen falta dos valores de ndice para referenciar un elemento en particular, de la
forma:
nombre_de_la_matriz [nmero_de_posicin] [nmero_de_posicin]
FILA COLUMNA
El siguiente diagrama representa una tabla o una matriz de 20 elementos (4 x 5) con 4 filas y 5
columnas, llamada MATRIZ:
COLUMNAS
elemento
0, 0
elemento
0, 1
elemento
0, 2
elemento
0, 3
elemento
0, 4
elemento
1, 0
elemento
1, 1
elemento
1, 2
elemento
1, 3
elemento
1, 4
elemento
2, 0
elemento
2, 1
elemento
2, 2
elemento
2, 3
elemento
2, 4
FILAS
elemento
3, 0
elemento
3, 1
elemento
3, 2
elemento
3, 3
elemento
3, 4
MATRIZ[2][2]
MATRIZ[1][4]
MATRIZ[3][4]
Las flechas indican cmo debe referenciarse algn elemento de la matriz.
Como en un vector de 20 elementos, cada uno de ellos es del mismo tipo de datos. Sin embargo, un
subndice no es suficiente para especificar un elemento de un arreglo bidimensional (matriz); por
ejemplo, si el nombre de la matriz es MAT, no se puede indicar MAT[3], ya que no sabemos si es el
cuarto elemento de una fila o de una columna.
Un arreglo bidimensional tambin denominado matriz (en trminos matemticos) o tabla (en trminos
financieros) se considera que tiene dos dimensiones (una dimensin por cada subndice) y necesita un
valor para cada subndice de manera que pueda identificar a un elemento en forma individual.
Para evitar la ambigedad, los elementos de una matriz se referencian con dos subndices: el primer
subndice se refiere a la fila y el segundo subndice se refiere a la columna. Por consiguiente,
MAT[2][3] se refiere al elemento que se encuentra en la tercera fila y cuarta columna. Puesto que al
igual que los vector, la primera fila de una matriz es 0 y la primera columna de una matriz es 0.
En notacin estndar, normalmente el primer subndice se refiere a la fila de la matriz, mientras que el
segundo subndice se refiere a la columna de la matriz. Es decir, T[I][J] es el elemento de T que ocupa
Carreras: Analista de Sistemas y Licenciatura en Sistemas
Asignatura: Resolucin de Problemas y Algoritmos
Docente: Lic. Vernica L. Vanoli
Apunte de Ctedra
- Pgina 63 de 165 -
la fila I+1 y la columna J+1. Estos subndices son tipos de datos ordinales, como lo son los Enteros o
Caracteres.
Por ejemplo se podra referenciar al elemento que se encuentra en la posicin [3][3] si se usa las
variables I y J, cuyo contenido en ese momento es de 3 cada una, o sea I:3, J:3, entonces todas las
siguientes referencias son iguales e indican el contenido de la celda [3][3], veamos:
T[I][J]: T[I][I]: T[J][I]: T[J][J]: T[3][I]: T[I][3]: T[J][3]: T[3][J]: T[3][3]
Ahora s I: 3 y J: 6, entonces:
T[I][J] : referencia al elemento ubicado en la fila 4 y en la columna 7.
T[J][I] : referencia al elemento ubicado en la fila 7 y en la columna 4.
T[I][I + 7] : referencia al elemento ubicado en la fila 4 y en la columna 11.
T[J][8] : referencia al elemento ubicado en la fila 7 y en la columna 9.
La matriz T se dice que tiene M por N elementos. Existen M elementos en cada fila y N elementos en
cada columna, por lo tanto, la matriz tiene a lo sumo (M * N) elementos. Si M es igual a N, se
denomina Matriz Cuadrada, caso contrario, es una Matriz No Cuadrada.
Declaracin y creacin de un arreglo bidimensional (Matriz)
Formato general:
Declaracin:
tipo_de_dato [ ] [ ] nombre_de_la_matriz
Creacin:
nombre_de_la_matriz = nuevo tipo_de_dato[cantidad_de_filas][cantidad_de_columnas]
Por ejemplo:
entero [ ][ ] MATRIZ real [ ][ ] TABLA
MATRIZ = nuevo entero[10][8] TABLA = nuevo real[100][100]
Otra forma de declarar una matriz, es por medio de constantes:
FIL = 10
COL = 8
entero [ ][ ] MATRIZ
MATRIZ = nuevo entero [FIL][COL]
Manejo de matrices
Una matriz es un arreglo de dos dimensiones, por lo tanto, las operaciones son similares que las de un
vector, slo que la diferencia se encuentra en cmo manejar los dos ndice.
Veamos como sera cargar una matriz de 10 x 10, en forma completa:
para (FILA 0; FILA <10; FILA FILA + 1)
para (COLUMNA 0; COLUMNA <10; COLUMNA COLUMNA + 1)
{
escribir Ingrese un valor en la posicin , FILA, , COLUMNA
leer MATRIZ[FILA][COLUMNA]
}
Carreras: Analista de Sistemas y Licenciatura en Sistemas
Asignatura: Resolucin de Problemas y Algoritmos
Docente: Lic. Vernica L. Vanoli
Apunte de Ctedra
- Pgina 64 de 165 -
En este caso, ha sido necesario recorrer las filas y las columnas (de izquierda a derecha y de arriba
hacia abajo) a travs de dos bucles anidados. La variable FILA, controla el primer bucle y representa
las filas, y la variable COLUMNA, controla el segundo bucle y representa las columnas.
Ejemplos.
Problema: Generar e imprimir una matriz de nmeros enteros.
principal ImprimirMatrizEnteros
{ //principal
//declaraciones
FILA = 50
COLUMNA = 50
entero [ ][ ] MATRIZ
MATRIZ = nuevo entero [FILA][COLUMNA]
entero FILAS, COLS, I, J //nmero de filas y nmero de columnas
//carga de dimensiones
escribir Ingrese cantidad de filas
leer FILAS
escribir Ingrese cantidad de columnas
leer COLS
//carga de datos
escribir Carga de los elementos a la matriz
para (I 0; I < FILAS; I I + 1)
{
escribir Ingrese dato para la fila: , I
para (J 0; J < COLS; J J + 1)
leer MATRIZ[I][J]
}
//muestra de datos
escribir La matriz resultante es la siguiente
para (I 0; I < FILAS; I I + 1)
para (J 0; J < COLS; J J + 1)
escribir MATRIZ[I][J]
} //principal
Problema: Generar dos matrices de enteros, calcular la suma de ambas (elemento a elemento) y
escribir la matriz de sumas resultante. Para resolver este problema primero cargamos dos matrices,
luego generamos la suma de stas en una tercera matriz y por ltimo mostramos los resultados.
principal DosMatrices
{ //principal
//declaraciones
entero [ ][ ] MAT1, MAT2, MAT3
MAT1 = nuevo entero [20][20]
MAT2 = nuevo entero [20][20]
MAT3 = nuevo entero [20][20] //MAT3 es la matriz de resultado
Carreras: Analista de Sistemas y Licenciatura en Sistemas
Asignatura: Resolucin de Problemas y Algoritmos
Docente: Lic. Vernica L. Vanoli
Apunte de Ctedra
- Pgina 65 de 165 -
entero FILAS, COLS, I, J //nmero de filas y nmero de columnas
//carga de dimensiones
escribir Ingrese cantidad de filas
leer FILAS
escribir Ingrese cantidad de columnas
leer COLS
//carga de la primera matriz
escribir Carga de los elementos de la primera matriz
para (I 0; I < FILAS; I I + 1)
{
escribir Ingrese dato para la fila: , I
para (J 0; J < COLS; J J + 1)
leer MAT1[I][J]
}
//carga de la segunda matriz
escribir Carga de los elementos de la segunda matriz
para (I 0; I < FILAS; I I + 1)
{
escribir Ingrese dato para la fila: , I
para (J 0; J < COLS; J J + 1)
leer MAT2[I][J]
}
//suma de MAT1 y MAT2
para (I 0; I < FILAS; I I + 1)
para (J 0; J < COLS; J J + 1)
MAT3[I][J] MAT1[I][J] + MAT2[I][J]
//muestra de los datos de MAT3
escribir La suma de las dos primeras matrices es la siguiente
para (I 0; I < FILAS; I I + 1)
para (J 0; J < COLS; J J + 1)
escribir MAT3[I][J]
} //principal
Problema: Dada una matriz de nmeros enteros imprimir los elementos de la 3er. columna.
principal ImprimirMatrizColumnaTres
{ //principal
//declaraciones
TOPE = 50
entero [ ][ ] MATRIZ
MATRIZ = nuevo entero [TOPE][TOPE]
entero FILAS, COLS, I, J
//carga de dimensiones
escribir Ingrese cantidad de filas
Carreras: Analista de Sistemas y Licenciatura en Sistemas
Asignatura: Resolucin de Problemas y Algoritmos
Docente: Lic. Vernica L. Vanoli
Apunte de Ctedra
- Pgina 66 de 165 -
leer FILAS
escribir Ingrese cantidad de columnas
leer COLS
//carga de datos
escribir Carga de los elementos a la matriz
para (I 0; I < FILAS; I I + 1)
{
escribir Ingrese dato para la fila: , I
para (J 0; J < COLS; J J + 1)
leer MATRIZ[I][J]
}
//muestra de datos
escribir Los elementos de la tercera columna son los siguientes
para (I 0; I < FILAS; I I + 1)
para (J 0; J < COLS; J J + 1)
si (J = = 2)
escribir MATRIZ[I][J]
} //principal
Otra posibilidad para mostrar los elementos de la tercera columna, sera:
para (I 0; I < FILAS; I I + 1)
escribir MATRIZ[I][2]
Con esta ltima forma evitamos recorrer toda la matriz innecesariamente. A veces, encontrar formas
de recorrido ms simples hace a los algoritmos ms rpidos.
Problema: Dada una matriz de nmeros enteros generar un vector donde cada elemento del mismo es
el resultado de la suma de los elementos de cada columna de la matriz.
Ejemplo:
Dada la siguiente Matriz:
3 6 4 8
0 4 1 3
4 0 7 8
El resultado sera el siguiente Vector:
7 10 12 19
El nmero 7 (VECTOR[0]) = 3 (MATRIZ[0][0]) + 0 (MATRIZ[1][0]) + 4 (MATRIZ[2][0]).
El nmero 10 (VECTOR[1]) = 6 (MATRIZ[0][1]) + 4 (MATRIZ[1][1]) + 0 (MATRIZ[2][1]).
El nmero 12 (VECTOR[2]) = 4 (MATRIZ[0][2]) + 1 (MATRIZ[1][2]) + 7 (MATRIZ[2][2]).
El nmero 19 (VECTOR[3]) = 8 (MATRIZ[0][3]) + 3 (MATRIZ[1][3]) + 8 (MATRIZ[2][3]).
Es muy importante ver el comportamiento de los ndices, como se mostr anteriormente.
Carreras: Analista de Sistemas y Licenciatura en Sistemas
Asignatura: Resolucin de Problemas y Algoritmos
Docente: Lic. Vernica L. Vanoli
Apunte de Ctedra
- Pgina 67 de 165 -
principal CrearVector
{ //principal
//declaraciones
FILA = 50
COLUMNA = 50
entero [ ][ ] MATRIZ
MATRIZ = nuevo entero [FILA][COLUMNA]
entero [ ] VECTOR
VECTOR = nuevo entero [COLUMNA]
entero FILAS, COLS
entero SUMA, I, J
//carga de dimensiones
escribir Ingrese cantidad de filas
leer FILAS
escribir Ingrese cantidad de columnas
leer COLS
//carga de datos
escribir Carga de los elementos a la matriz
para (I 0; I < FILAS; I I + 1)
{
escribir Ingrese dato para la fila: , I
para (J 0; J < COLS; J J + 1)
leer MATRIZ[I][J]
}
//generacin del vector
//el recorrido lo vamos a hacer por columnas
para (J 0; J < COLS; J J + 1)
{
SUMA 0
para (I 0; I < FILAS; I I + 1)
SUMA SUMA + MATRIZ[I][J]
VECTOR[J] SUMA
}
//muestra del vector
escribir El vector resultante es la siguiente
para (I 0; I < COLS; I I + 1)
escribir VECTOR[I]
} //principal
Los mtodos de ordenacin (clasificacin) vistos anteriormente y aplicados a vectores se pueden
extender a matrices o tablas considerando la ordenacin respecto a una fila o columna. Lo mismo con
los mtodos de bsqueda para matrices, adaptndolos.
Carreras: Analista de Sistemas y Licenciatura en Sistemas
Asignatura: Resolucin de Problemas y Algoritmos
Docente: Lic. Vernica L. Vanoli
Apunte de Ctedra
- Pgina 68 de 165 -
DISEO DE ALGORITMOS: FUNCIONES
Tras la fase de anlisis, para poder solucionar problemas sobre la computadora, debe conocerse como
disear algoritmos. En la prctica sera deseable disponer de un mtodo para escribir algoritmos, pero,
en la realidad no existe. El diseo de algoritmos es un proceso creativo. Sin embargo, existen una serie
de pautas o lneas a seguir que ayudarn al diseo de algoritmos:
1. Formular una solucin precisa del problema que debe solucionar el algoritmo.
2. Ver si existe ya algn algoritmo para resolver el problema o bien se puede adaptar uno ya
conocido (algoritmos conocidos).
3. Buscar si existen tcnicas estndar que se pueden utilizar para resolver el problema.
4. Elegir una estructura de datos adecuada.
5. Dividir el problema en subproblemas y aplicar el mtodo a cada uno de los subproblemas
(funciones).
De cualquier forma, antes de iniciar el diseo del algoritmo es preciso asegurarse que el programa est
bien definido:
Especificaciones precisas y completas de las entradas necesarias.
Especificaciones precisas y completas de las salidas.
Cmo debe reaccionar el programa ante datos incorrectos?.
Se emiten mensajes de error?, se detiene el proceso?, etc.
Conocer cundo y cmo debe terminar un programa.
Haciendo hincapi al punto 5 que se refiere a solucionar los siguientes problemas:
Un programa realiza varias tareas, por lo tanto, se compone de muchos algoritmos, lo que lleva a
una escritura extensa y confusa.
La deteccin y correccin de errores en segmentos especficos de cdigo en dicho programa se
dificulta, dada la longitud del mismo.
Un mismo algoritmo u operacin se repite en varias partes dentro del mismo programa
(redundancia o repeticin de informacin).
Respecto al ltimo problema, a menudo, determinadas tareas o algoritmos se realizan mas de una vez
en el mismo programa en diferentes partes, por lo tanto, lo que hacemos es repetir secuencias de
cdigo iguales. Por ejemplo, si hablamos de una secuencia de 100 nmeros cuyos valores deben
mantenerse para su utilizacin posterior y queremos aplicar a cada uno de ellos la operacin de
factorial, deberamos repetir dicha operacin 100 veces. Por lo tanto, una forma de escribir programas
ms cortos y flexibles, sera dividir el programa en funciones y de esta manera, estaramos
solucionando el problema planteado hasta el momento. Es decir, que para este ejemplo se creara una
funcin factorial (se escribe el cdigo de factorial una sola vez) y se la usara y aprovechara para los
100 nmeros de la secuencia.
Veamos otro ejemplo de redundancia o repeticin de informacin (cdigo). Si un programa debe
obtener el mayor promedio de dos vectores de diferentes dimensiones realizar las cargas, el clculo
del promedio y la muestra de los vectores por separado.
principal EjemploDeRedundancia
{ //principal
//declaracin de variables
real PROM1, PROM2
Carreras: Analista de Sistemas y Licenciatura en Sistemas
Asignatura: Resolucin de Problemas y Algoritmos
Docente: Lic. Vernica L. Vanoli
Apunte de Ctedra
- Pgina 69 de 165 -
entero SUMA, CONT
entero [ ] VECTOR1
VECTOR1 = nuevo entero [100]
entero [ ] VECTOR2
VECTOR2 = nuevo entero [50]
//carga del primer vector
para (CONT 0; CONT < 100; CONT CONT + 1)
leer VECTOR1[CONT]
//carga del segundo vector
para (CONT 0; CONT < 50; CONT CONT + 1)
leer VECTOR2[CONT]
//sumatoria y promedio de los elementos del primer vector
SUMA 0
para (CONT 0; CONT < 100; CONT CONT + 1)
SUMA SUMA + VECTOR1[CONT]
PROM1 SUMA / 100
//sumatoria y promedio de los elementos del segundo vector
SUMA 0
para (CONT 0; CONT < 50; CONT CONT + 1)
SUMA SUMA + VECTOR2[CONT]
PROM2 SUMA / 50
//comparacin de promedios
si (PROM1 > PROM2)
escribir El mayor promedio es: , PROM1
sino
escribir El mayor promedio es: , PROM2
//muestra del primer vector
para (CONT 0; CONT < 100; CONT CONT + 1)
escribir VECTOR1[CONT]
//muestra del segundo vector
para (CONT 0; CONT < 50; CONT CONT + 1)
escribir VECTOR2[CONT]
} //principal
Como vemos, el algoritmo para cargar un vector es el mismo independientemente de su dimensin. Lo
mismo ocurre para calcular el promedio o mostrar el contenido de los vectores. Si en este programa se
trabajara con 15 vectores, resultara muy extenso y confuso. Adems, siempre se estara repitiendo lo
mismo (carga, promedio y muestra).
Como se dijo anteriormente, lo ms conveniente es dividir o estructurar el programa en funciones.
Sera, realizar una funcin por cada algoritmo de nuestro programa. Una forma de plantear esta tcnica
es dividir un problema en subproblemas y para cada subproblema plantear un algoritmo y a cada
Carreras: Analista de Sistemas y Licenciatura en Sistemas
Asignatura: Resolucin de Problemas y Algoritmos
Docente: Lic. Vernica L. Vanoli
Apunte de Ctedra
- Pgina 70 de 165 -
algoritmo le corresponder una funcin. El objetivo de cada funcin seria que tenga una tarea
especfica a realizar. Entonces, el programa se divide en funciones (partes independientes), cada una
de las cuales ejecuta una nica actividad o tarea y se codifican independientemente de otras funciones.
Cada programa contiene una funcin denominada Principal que es el punto de partida de ejecucin del
programa; se transfiere el control a funciones, de modo que ellas puedan ejecutar sus operaciones.
Si la tarea asignada a cada funcin es demasiado compleja; sta deber romperse en otras funciones
ms pequeas. El proceso sucesivo de subdivisin de funciones contina hasta que cada funcin tenga
solamente una tarea especfica a ejecutar. Una funcin puede transferir temporalmente (bifurcacin) el
control a otra funcin; sin embargo, cada funcin debe devolver el control a la funcin del cual recibe
originalmente el control.
Para las tareas que deben efectuarse ms de una vez, las funciones evitan la necesidad de
programacin redundante (repetida) de un mismo conjunto de instrucciones, ya que una funcin
puede ser definida una vez y llamada luego tantas veces como sea necesario. El uso de funciones
puede reducir apreciablemente la longitud de un programa.
Luego de todo lo expuesto anteriormente, podemos decir que las ventajas de utilizar funciones son:
Programas ms legibles y claros.
Programas mas cortos.
Disminuye la programacin repetida (reuso de cdigo).
Mayor flexibilidad en el mantenimiento.
Facilita la prueba y depuracin de errores.
Funciones
Matemticamente, una funcin es una operacin que toma uno o ms valores llamados argumentos y
retorna ninguno, uno o varios valores, lo que se denomina resultado.
Por ejemplo:
FUNCION Cuadrado
X
2
= Y
ARGUMENTO RESULTADO
De manera muy parecida diremos que una funcin es un subprograma que recibe uno o varios
argumentos (parmetros), realiza algn proceso o clculo y devuelve o entrega un resultado al
programa que la llam o invoc.
El formato general de la declaracin de una funcin es:
Tipo_de_dato nombre_de_la_funcin(tipo_de_dato parmetro1, tipo_de_dato parmetro2,...)
{
declaracin_de_variables_locales
...
cuerpo_de_la_funcin
...
retornar [resultado]
}
Carreras: Analista de Sistemas y Licenciatura en Sistemas
Asignatura: Resolucin de Problemas y Algoritmos
Docente: Lic. Vernica L. Vanoli
Apunte de Ctedra
- Pgina 71 de 165 -
Donde:
Tipo_de_dato es el tipo de dato del resultado que devuelve la funcin.
nombre_de_la_funcin es el identificador o nombre que identifica a la funcin.
parmetro1, parmetro2, ... es una lista de parmetros formales o argumentos, en la cual se
indica el tipo de datos y nombre de los mismos (separados por
coma). Puede estar compuesta de ninguno, uno o ms
parmetros.
cuerpo de la funcin es el conjunto de declaraciones y sentencias que ejecuta la
funcin.
retornar es la instruccin que permite a la funcin devolver su
resultado.
El cuerpo de la funcin debe ser una operacin que no requiera una lectura de datos, dado que los
datos que necesite la funcin sern entregados por los parmetros. Por lo tanto, no se puede utilizar el
leer dentro de la funcin. La devolucin de una funcin puede ser de tres tipos de resultado: un valor
de tipo simple, un valor de tipo compuesto/objeto o nada. En este ltimo caso, no se coloca tipo de
dato de la funcin y la instruccin retornar va sin nada. Dado que una funcin es un subprograma,
tiene prcticamente la misma forma que un programa: una cabecera, declaraciones de datos y un
cuerpo (conjunto de sentencias).
Ejemplos.
Problema: Escribir una funcin que devuelva el cubo de un valor.
entero Cubo(entero X)
{
//declaracin de variables
entero AUXCUBO
//clculo del cubo
AUXCUBO X * X * X
//retorno del resultado
retornar AUXCUBO
}
Entero es el tipo de dato que devuelve la funcin, Cubo es el nombre de la funcin, y el clculo se
realiza utilizando el parmetro X de tipo entero y una variable local de tipo entero llamada
AUXCUBO. Luego, mediante RETORNAR se devuelve el resultado almacenado en AUXCUBO.
Problema: Crear una funcin que verifique si un nmero es par o no.
booleano esPar(entero NUM)
{
//declaracin de variables
booleano RESUL
//evaluacin par o impar
si (NUM % 2 = = 0)
RESUL Verdadero
Carreras: Analista de Sistemas y Licenciatura en Sistemas
Asignatura: Resolucin de Problemas y Algoritmos
Docente: Lic. Vernica L. Vanoli
Apunte de Ctedra
- Pgina 72 de 165 -
sino
RESUL Falso
//retorno del resultado
retornar RESUL
}
Otra manera vlida de escribir la funcin sin usar una variable local, es de la siguiente manera:
booleano esPar(entero NUM)
{
//evaluacin para par o impar y retorno del resultado
si (NUM % 2 = = 0)
retornar Verdadero
sino
retornar Falso
}
Problema: Crear una funcin que a partir de un nmero entero retorne 1, cuando sea positivo, 0 cuando
sea 0 y -1 cuando sea negativo.
entero positivoCeroNegativo(entero NUM)
{
//evaluacin y retorno del resultado
si (NUM > 0)
retornar 1
sino
si (NUM = = 0)
retornar 0
sino
retornar -1
}
Problema: Mostrar el nombre del mes correspondiente un valor entero ingresado. Ej.: 5 sera Mayo.
nombreMes(entero MES)
{
//evaluacin y muestreo
alternar (MES)
{
caso 1 : {
escribir ENERO
corte
}
caso 2 : {
escribir FEBRERO
corte
}
Carreras: Analista de Sistemas y Licenciatura en Sistemas
Asignatura: Resolucin de Problemas y Algoritmos
Docente: Lic. Vernica L. Vanoli
Apunte de Ctedra
- Pgina 73 de 165 -
caso 3 : {
escribir MARZO
corte
}
caso 4 : {
escribir ABRIL
corte
}
caso 5 : {
escribir MAYO
corte
}
caso 6 : {
escribir JUNIO
corte
}
caso 7 : {
escribir JULIO
corte
}
caso 8 : {
escribir AGOSTO
corte
}
caso 9 : {
escribir SEPTIEMBRE
corte
}
caso 10 : {
escribir OCTUBRE
corte
}
caso 11 : {
escribir NOVIEMBRE
corte
}
caso 12 : {
escribir DICIEMBRE
corte
}
caso contrario
escribir NUMERO DE MES INCORRECTO
}
retornar
}
En este caso, se ilustra como una funcin no devolvera nada. Es decir, la salida es implcita, dado que
estara representada por los escribir.
Carreras: Analista de Sistemas y Licenciatura en Sistemas
Asignatura: Resolucin de Problemas y Algoritmos
Docente: Lic. Vernica L. Vanoli
Apunte de Ctedra
- Pgina 74 de 165 -
Problema: De acuerdo a dos caracteres retornar el menor de ellos.
caracter menorCaracter(caracter CAR1, caracter CAR2)
{
//evaluacin para menor y muestreo
si (CAR1 < CAR2)
retornar CAR1
sino
retornar CAR2
}
Problema: Hacer una funcin que devuelva la sumatoria de los elementos de un vector, otra funcin
que vace el vector (todos valores 0) y otra funcin que muestre el contenido del vector.
entero sumatoriaElementos(entero [ ] VECTOR, entero DIM)
{
//declaracin de variables
entero CONT, SUMA
//clculo de la sumatoria
SUMA 0
para (CONT 0; CONT < DIM; CONT CONT + 1)
SUMA SUMA + VECTOR[CONT]
retornar SUMA
}
entero [ ] vaciarVector(entero [ ] VECTOR, entero DIM)
{
//declaracin de variables
entero CONT
//vaciado del vector
para (CONT 0; CONT < DIM; CONT CONT + 1)
VECTOR[CONT] 0
retornar VECTOR
}
muestraVector(entero [ ] VECTOR, entero DIM)
{
//declaracin de variables
entero CONT
//muestreo del vector
para (CONT 0; CONT < DIM; CONT CONT + 1)
escribir VECTOR[CONT]
retornar
}
Carreras: Analista de Sistemas y Licenciatura en Sistemas
Asignatura: Resolucin de Problemas y Algoritmos
Docente: Lic. Vernica L. Vanoli
Apunte de Ctedra
- Pgina 75 de 165 -
En estos ltimo ejemplo, se ilustra los tres tipos de resultados que puede devolver una funcin: un
valor de tipo simple, un valor de tipo compuesto/objeto o nada (donde no se coloca el tipo de dato de
la funcin y la instruccin retornar va sin nada).
Aserciones: Precondiciones y Postcondiciones
Un programa no puede decirse que sea correcto o incorrecto per se; es correcto o incorrecto con
respecto a cierta especificacin (descripcin precisa de lo que se supone que el programa debe hacer).
Estrictamente hablando, no se debera discutir sobre si un programa es o no correcto, sino sobre si es
consistente con sus especificaciones. Esta discusin continuar utilizando el trmino bien aceptado de
correccin pero siempre se debe recordar que la pregunta de si es correcto no se aplica a programas;
se aplica a pares formados por un programa y una especificacin.
Para expresar la especificacin confiaremos en las aserciones. Una asercin es una expresin que
involucra algunas entidades del software y que establece una propiedad que dichas entidades deben
satisfacer en ciertas etapas de la ejecucin de un programa. Una tpica asercin puede ser la que
expresa que un entero es positivo.
Se puede especificar la tarea que lleva a cabo una funcin mediante dos aserciones asociadas a la
funcin: una precondicin y una postcondicin.
Una precondicin es una informacin que se conoce como verdadera antes de iniciar la funcin.
La precondicin establece las propiedades que se tienen que cumplir cada vez que se llame a la
funcin. Por ejemplo: si utilizamos a la funcin nombreMes(entero) vista anteriormente, podemos
decir que la precondicin sera que el valor entero debe ser positivo y pertenecer al rango de valores
entre el 1 y el 12.
Una postcondicin es una informacin que debiera ser verdadera al concluir una funcin, si se
cumple adecuadamente el requerimiento pedido.
La postcondicin establece las propiedades que debe garantizar la funcin cuando retorne. Por
ejemplo: en el caso de la funcin menorCaracter(caracter, caracter) debera devolver como
postcondicin un valor de tipo caracter igual a uno de los datos que ingresan por parmetro (que debe
ser el menor de ellos).
Invocacin a la funcin
La llamada a una funcin se realiza de la siguiente manera:
variable nombre_de_la_funcin(parmetro1, parmetro2, ...)
(si la funcin retorna un resultado simple o compuesto/objeto)
nombre_de_la_funcin(parmetro1, parmetro2, ...)
(si la funcin no retorna ningn resultado)
Donde:
variable es la variable del programa llamador.
nombre_de_la_funcin es el identificador o nombre de la funcin que se llama.
parmetro1, parmetro2, ... es una lista de parmetros actuales, en la cual se indica el
nombre de los mismos (separados por coma). Pueden ser
constantes, variables o expresiones. Puede estar compuesta de
ninguno, uno o ms parmetros.
Carreras: Analista de Sistemas y Licenciatura en Sistemas
Asignatura: Resolucin de Problemas y Algoritmos
Docente: Lic. Vernica L. Vanoli
Apunte de Ctedra
- Pgina 76 de 165 -
Por ejemplo, veamos cmo la funcin cubo se incorpora en un programa que la utiliza o invoca.
{
principal CuboNumero
{ //principal
//declaracin de variables
entero NUM, AUX
//carga del valor
escribir Ingrese un valor
leer NUM
//invocacin a la funcin y asignacin del resultado a una variable
AUX Cubo(NUM)
//muestra del resultado
escribir El cubo de , NUM, es: , AUX
} //principal
//funcin que calcula el cubo de un nmero entero
//precondicin: valor entero
//postcondicin: valor entero elevado a 3
entero Cubo(entero X)
{
//declaracin de variables
entero AUXCUBO
//clculo del cubo
AUXCUBO X * X * X
//retorno del resultado
retornar AUXCUBO
}
}
Cuando este programa se ejecute, luego de que se lea NUM, el principal llama a la funcin (pasa el
control a la funcin), usando NUM como argumento, la funcin se ejecuta y devuelve su resultado
asignndolo a la variable AUX.
Un programa se divide en funciones; y Principal es una funcin ms que no devuelve nada y que tiene
la caracterstica particular de que en todo programa la ejecucin comienza por ella misma.
Orden de ejecucin
Cuando un programa se ejecute, siempre comienza por la primer sentencia del principal, el flujo de
control se desplaza de acuerdo al tipo de estructuras de control (secuencia, seleccin, iteracin),
cuando ocurre una llamada a una funcin, se interrumpe la ejecucin del principal y la funcin toma el
control y se ejecuta por completo (comenzando en su primer lnea, hasta llegar a la ltima). Cuando la
funcin finaliza su ejecucin, el control retorna al principal o al punto dnde fue interrumpido y
contina su ejecucin.
A continuacin veremos un ejemplo de un programa que trabaja con un arreglo de enteros, utilizando
los tres casos vistos anteriormente del ltimo ejemplo de funciones con vectores.
Carreras: Analista de Sistemas y Licenciatura en Sistemas
Asignatura: Resolucin de Problemas y Algoritmos
Docente: Lic. Vernica L. Vanoli
Apunte de Ctedra
- Pgina 77 de 165 -
{
principal TrabajoConArreglo
{ //principal
//declaracin de variables
entero DIM, SUMATORIA, CONTADOR
entero [ ] VEC
VEC = nuevo entero [100]
//carga de la dimensin
escribir Ingrese la dimensin del vector
leer DIM
//carga del vector
para (CONTADOR 0; CONTADOR < DIM; CONTADOR CONTADOR + 1)
leer VEC[CONTADOR]
//invocacin a la funcin y asignacin del resultado a una variable
SUMATORIA sumatoriaElementos(VEC, DIM)
//muestra del resultado
escribir La sumatoria del vector es: , SUMATORIA
//muestra del vector
muestraVector(VEC, DIM)
//vaciado del vector
VEC vaciarVector(VEC, DIM)
//muestra del vector
muestraVector(VEC, DIM)
} //principal
//funcin que calcula la sumatoria de los elementos del vector
//precondicin: vector con elementos enteros y dimensin vlida
//postcondicin: resultado entero de la suma de los elementos del vector
entero sumatoriaElementos(entero [ ] VECTOR, entero D)
{
.
.
.
}
//funcin que vaca el contenido de un vector (colocando en 0 cada elemento)
//precondicin: vector con elementos enteros y dimensin vlida
//postcondicin: vector vaco
entero [ ] vaciarVector(entero [ ] VECTOR, entero D)
{
.
.
.
}
Carreras: Analista de Sistemas y Licenciatura en Sistemas
Asignatura: Resolucin de Problemas y Algoritmos
Docente: Lic. Vernica L. Vanoli
Apunte de Ctedra
- Pgina 78 de 165 -
//funcin que muestra el contenido de un vector
//precondicin: vector con elementos enteros y dimensin vlida
//postcondicin: muestreo de los elementos del vector
muestraVector(entero [ ] VECTOR, entero D)
{
.
.
.
}
}
Conceptos fundamentales de una funcin
Veamos nuevamente el programa CuboNumero distinguiendo algunos conceptos fundamentales.
{
principal CuboNumero
{ //principal
//declaracin de variables
entero NUM, AUX
//carga del valor
escribir Ingrese un valor
leer NUM
//invocacin a la funcin y asignacin del resultado a una variable
AUX Cubo(NUM)
//muestra del resultado
escribir El cubo de , NUM, es: , AUX
} //principal
//funcin que calcula el cubo de un nmero entero
//precondicin: valor entero
//postcondicin: valor entero elevado a 3
entero Cubo(entero X)
{
//declaracin de variables
entero AUXCUBO
.
.
.
}
}
Se han indicado aqu dos conceptos fundamentales de la programacin modular:
Variables Locales.
Parmetros (Actuales y Formales).
VARIABLES
LOCALES DEL
PRINCIPAL
PARAMETRO
ACTUAL
PARAMETRO
FORMAL
VARIABLE
LOCAL DE LA
FUNCION
Carreras: Analista de Sistemas y Licenciatura en Sistemas
Asignatura: Resolucin de Problemas y Algoritmos
Docente: Lic. Vernica L. Vanoli
Apunte de Ctedra
- Pgina 79 de 165 -
Variables Locales
Una variable local es una variable que est declarada dentro de una funcin, y se dice que es local a la
funcin. Una variable local slo est disponible durante la ejecucin de la misma. Su valor se pierde o
se destruye una vez que la funcin finaliza su ejecucin, es decir, cuando se retorna a la funcin
llamadora.
El concepto subyacente es el de tiempo de vida de un identificador, cuando una variable es local, su
existencia o vida se restringe a la ejecucin de la funcin en que esta declarada. Entonces, en forma
genrica recalcamos que si tenemos una variable local llamada X en la funcin P, no podremos usar a
X fuera de P.
Parmetros
Corresponde a la transferencia de informacin entre funciones, a travs de una lista de parmetros. Un
parmetro es una tcnica para pasar informacin - valores a variables - de una funcin a otra y
viceversa. En pocas ocasiones, podemos aplicar funciones sin parmetros, como el principal que es
una funcin que no requiere parmetros de entrada.
Parmetro
de
Entrada
FUNCION LLAMADA
FUNCION LLAMADORA
Retorno
de
Salida
Como se ilustra en el grfico, un parmetro es una variable cuyo valor debe ser proporcionado desde la
funcin llamadora a la funcin llamada. La funcin llamada, con el parmetro de entrada realiza
ciertas operaciones, de la que obtiene un resultado y lo transmite como retorno de salida a la funcin
llamadora. Como puede observarse en el programa CuboNumero, el parmetro de entrada de la
funcin Cubo es un entero, que lo proporciona el principal.
Lista de parmetros actuales y formales
Los parmetros utilizados cuando se llama a una funcin se denominan parmetros actuales, stos
son variables de la funcin llamadora (ver el parmetro NUM del programa CuboNumero). Cuando en
la funcin se incluye una lista de parmetros con sus correspondientes tipos, a stos parmetros los
denominamos parmetros formales.
El uso de parmetros ofrece una tcnica para el intercambio de informacin entre funciones. Cada dato
se transfiere entre un parmetro actual incluido dentro de la referencia (invocacin a una funcin), y
un parmetro formal correspondiente, definido dentro de la funcin llamada. Cuando se invoca a la
funcin, los parmetros actuales son reemplazados por los parmetros formales, creando as un
mecanismo de intercambio de informacin entre funciones.
Modifiquemos el programa TrabajoConArreglo para que realice todas las operaciones con dos
arreglos.
Carreras: Analista de Sistemas y Licenciatura en Sistemas
Asignatura: Resolucin de Problemas y Algoritmos
Docente: Lic. Vernica L. Vanoli
Apunte de Ctedra
- Pgina 80 de 165 -
{
principal TrabajoConArreglo
{ //principal
//declaracin de variables
entero DIM, SUMA1, SUMA2, CONTADOR
entero [ ] VEC1, VEC2
VEC1 = nuevo entero [100]
VEC2 = nuevo entero [100]
//carga de la dimensin
escribir Ingrese la dimensin del vector
leer DIM
//carga del primer vector
para (CONTADOR 0; CONTADOR < DIM; CONTADOR CONTADOR + 1)
leer VEC1[CONTADOR]
//carga del segundo vector
para (CONTADOR 0; CONTADOR < DIM; CONTADOR CONTADOR + 1)
leer VEC2[CONTADOR]
//invocacin a la funcin con el primer vector y asignacin del resultado a una variable
SUMA1 sumatoriaElementos(VEC1, DIM)
//invocacin a la funcin con el segundo vector y asignacin del resultado a una variable
SUMA2 sumatoriaElementos(VEC2, DIM)
//muestra de los resultados
escribir La sumatoria del primer vector es: , SUMA1
escribir La sumatoria del segundo vector es: , SUMA2
//muestra del primer vector
muestraVector(VEC1, DIM)
//muestra del segundo vector
muestraVector(VEC2, DIM)
//vaciado del primer vector
VEC1 vaciarVector(VEC1, DIM)
//vaciado del segundo vector
VEC2 vaciarVector(VEC2, DIM)
//muestra del primer vector
muestraVector(VEC1, DIM)
//muestra del segundo vector
muestraVector(VEC2, DIM)
} //principal
Carreras: Analista de Sistemas y Licenciatura en Sistemas
Asignatura: Resolucin de Problemas y Algoritmos
Docente: Lic. Vernica L. Vanoli
Apunte de Ctedra
- Pgina 81 de 165 -
//funcin que calcula la sumatoria de los elementos del vector
//precondicin: vector con elementos enteros y dimensin vlida
//postcondicin: resultado entero de la suma de los elementos del vector
entero sumatoriaElementos(entero [ ] VECTOR, entero D)
{
.
.
.
}
//funcin que vaca el contenido de un vector (colocando en 0 cada elemento)
//precondicin: vector con elementos enteros y dimensin vlida
//postcondicin: vector vaco
entero [ ] vaciarVector(entero [ ] VECTOR, entero D)
{
.
.
.
}
//funcin que muestra el contenido de un vector
//precondicin: vector con elementos enteros y dimensin vlida
//postcondicin: muestreo de los elementos del vector
muestraVector(entero [ ] VECTOR, entero D)
{
.
.
.
}
}
En este ejemplo podemos ver que las funciones sumatoriaElementos, vaciarVector y muestraVector no
se han tenido que modificar, slo se tuvo que agregar al programa una llamada ms a cada una de las
funciones. Y en cada llamada lo que varia es el parmetro actual (VEC1 y VEC2). El parmetro
formal (VECTOR) se reemplazar por el parmetro actual cuando la funcin sea llamada.
De esta manera, al utilizar parmetros podemos llamar a una funcin muchas veces para que realice el
mismo clculo con diferentes valores, sta es una de las ventajas de trabajar con funciones.
En una funcin si usamos un determinado identificador, ste es o una variable local de la funcin o
pertenece a la lista de parmetros formales a dicha funcin. CASO CONTRARIO, es incorrecto el uso
de dicho identificador.
Correspondencia de parmetros
Los parmetros actuales en la invocacin a una funcin deben coincidir en nmero, orden y tipo con
los parmetros formales de la declaracin de una funcin. Es decir debe existir una correspondencia de
parmetros.
A continuacin veremos un ejemplo genrico de correspondencia de parmetros, para explicar los tres
puntos nombrados.
Carreras: Analista de Sistemas y Licenciatura en Sistemas
Asignatura: Resolucin de Problemas y Algoritmos
Docente: Lic. Vernica L. Vanoli
Apunte de Ctedra
- Pgina 82 de 165 -
{
principal Correspondencia
{
entero VariableX, VariableY
real VariableZ
.
.
.
VariableX Corresponde(VariableY, VariableZ)
.
.
.
}
entero Corresponde (entero Parmetro1, real Parmetro2)
{
.
.
.
}
}
Nmero: la cantidad de parmetros actuales es 2 y la cantidad de parmetros formales es 2.
Orden: al parmetro actual VariableY le corresponde el parmetro formal Parmetro1 (ambos son
los primeros en la lista); al parmetro actual VariableZ le corresponde el parmetro formal
Parmetro2 (ambos son los segundos en la lista).
Tipo: VariableY y Parmetro1 son de tipo entero; VariableZ y Parmetro2 son de tipo real.
La funcin Corresponde entrega un valor entero, por lo tanto, la variable del principal que recibe el
resultado de esta funcin, en este caso VariableX, tambin debe ser entero. Es decir, tambin debe
coincidir el tipo de datos de la variable a la cual se le asigna el resultado de la funcin, con el tipo de
datos de retorno de la funcin.
Veamos otro ejemplo de funciones, dnde se calcula el mximo comn divisor de dos nmeros
enteros.
{
principal MaximoComunDivisor
{ //principal
//declaracin de variables
entero MCD, NRO1, NRO2
//carga de datos
escribir Ingrese dos nmeros enteros
leer NRO1, NRO2
//llamada a la funcin
MCD MaxComDiv(NRO1, NRO2)
//muestra de resultado
escribir El mximo comn divisor entre , NRO1, y , NRO2, es: , MCD
} //principal
Carreras: Analista de Sistemas y Licenciatura en Sistemas
Asignatura: Resolucin de Problemas y Algoritmos
Docente: Lic. Vernica L. Vanoli
Apunte de Ctedra
- Pgina 83 de 165 -
//funcin que calcula el mximo comn divisor de dos nmeros enteros
//precondicin: 2 nmeros enteros
//postcondicin: mximo comn divisor de esos 2 nmeros enteros
entero MaxComDiv(entero N1, entero N2)
{
//declaracin de variables
entero COCIENTE, RESTO
//clculo del mximo comn divisor
hacer
{
COCIENTE N1 / N2
RESTO N1 % N2
si (RESTO != 0)
{
N1 N2
N2 RESTO
}
}
mientras (RESTO != 0)
//retorno del resultado
retornar N2
}
}
Visibilidad de identificadores
Un identificador es el nombre de una funcin, variable, constante o parmetro. Un programa se
compone por lo general de varias funciones, estas funciones utilizan variables, constantes y
parmetros. Puede ocurrir que dos funciones utilicen una variable con el mismo identificador.
{
principal P
{
//declaracin de variables locales a P
.
.
.
}
Funcin F1 (lista de parmetros)
{
//declaracin de variables locales a F1
.
.
.
}
Funcin F2 (lista de parmetros)
{
//declaracin de variables locales a F2
.
.
Carreras: Analista de Sistemas y Licenciatura en Sistemas
Asignatura: Resolucin de Problemas y Algoritmos
Docente: Lic. Vernica L. Vanoli
Apunte de Ctedra
- Pgina 84 de 165 -
.
}
Funcin F3 (lista de parmetros)
{
//declaracin de variables locales a F3
.
.
.
}
}
En este esquema tenemos el principal P y tres funciones (F1, F2 y F3). Todas estas funciones poseen
su propia lista de parmetros y sus propias declaraciones locales. Grficamente podemos ilustrar el
esquema de la siguiente manera:
Programa
P F1 F2 F3
Con este ejemplo, se puede plantear la siguiente duda: las variables declaradas en P pueden utilizarse
en F1 y en F2?. Para responder a esta pregunta, debemos retomar el concepto de tiempo de vida de un
identificador y agregar el concepto de mbito de un identificador.
mbito de un identificador
Un bloque de funcin se compone de una cabecera (tipo de dato, nombre y lista de parmetros) y un
cuerpo de sentencias (declaraciones de variables y constantes e instrucciones). Tanto el principal como
el resto de las funciones, son bloques de funcin.
Los bloques en los que un identificador (variable y constante) puede ser utilizado se conoce como
mbito del identificador; dicho de otro modo, el mbito es la seccin de un programa en la que un
identificador es vlido.
Para saber concretamente la respuesta a la pregunta formulada en la seccin anterior, hemos de
guiarnos por las reglas de mbito.
Primer Regla de mbito:
El mbito de un identificador es el dominio en que est declarado. Por consiguiente, un identificador
declarado en el bloque P puede ser representado en P.
De acuerdo al esquema que hemos realizado anteriormente, ahora estamos en condiciones de asegurar:
Las variables declaradas en principal P, pueden slo ser utilizadas en P; no pueden ser utilizadas fuera
de l, es decir, en F1, F2 y F3.
Las variables declaradas en F1, pueden slo ser utilizadas en F1. Lo mismo para las funciones F2 y
F3.
Segunda Regla de mbito:
El mbito de un parmetro formal es idntico al mbito de una variable local de la misma funcin.
Carreras: Analista de Sistemas y Licenciatura en Sistemas
Asignatura: Resolucin de Problemas y Algoritmos
Docente: Lic. Vernica L. Vanoli
Apunte de Ctedra
- Pgina 85 de 165 -
Clases/Objetos: Tipos de Datos Compuesto
Antes de comenzar a hablar de las clases y los objetos, vamos a conocer algunos conceptos que nos
llevarn al uso de estos tipos de datos.
Orientacin a Objetos (OO)
La orientacin a objetos puede describirse como el conjunto de disciplinas que desarrollan y modelan
software que facilitan la construccin de sistemas complejos a partir de componentes.
El atractivo intuitivo de la OO es que proporciona conceptos y herramientas con las cuales se modela y
representa el mundo real tan fielmente como sea posible. Las ventajas de la OO son muchas en
programacin y modelacin de datos. Como apuntaban Ledbetter y Cox (1985):
La POO (Programacin Orientada a Objetos) permite una representacin ms directa del modelo de
mundo real en el cdigo. El resultado es que la transformacin radical normal de los requisitos del
sistema (definidos en trminos de usuario) a la especificacin del sistema (definido en trminos de
computacin) se reduce considerablemente.
Elementos de Geometra (mundo real)
clase Punto
clase Rectangulo
clase Circulo
clase Linea
Mdulos del Sistema Geometra
caractersticas
de los
elementos
distintas
instancias
de cada clase
las instancias
tienen las mismas
propiedades
de los objetos reales
Rectangulo Punto
Circulo Linea
Objetos de cada Clase
Carreras: Analista de Sistemas y Licenciatura en Sistemas
Asignatura: Resolucin de Problemas y Algoritmos
Docente: Lic. Vernica L. Vanoli
Apunte de Ctedra
- Pgina 86 de 165 -
Los conceptos y herramientas OO son tecnologas que permiten que los problemas del mundo real
sean expresados de modo fcil y natural. Las tcnicas OO proporcionan mejoras metodolgicas para
construir sistemas de software ms fiables a partir de unidades de software modularizado y
reutilizable.
El enfoque OO es capaz de manipular tanto sistemas grandes como pequeos, y crear sistemas fiables
que sean flexibles, mantenibles y capaces de evolucionar para cumplir las necesidades de cambio.
Estas tareas se realizan mediante la modelizacin del mundo real. El soporte fundamental es el modelo
objeto. Los cuatro elementos (propiedades) ms importantes de este modelo son:
Abstraccin.
Encapsulacin.
Modularidad.
Jerarqua (tema que se ver ms adelante).
Abstraccin
La abstraccin es uno de los medios ms importantes mediante el cual nos enfrentamos con la
complejidad inherente al software. La abstraccin es la propiedad que permite representar las
caractersticas esenciales de un objeto, sin preocuparse de las restantes caractersticas (no esenciales).
Una abstraccin se centra en la vista externa de un objeto, de modo que sirva para separar el
comportamiento esencial de un objeto, de su implementacin. Definir una abstraccin significa
describir una entidad del mundo real, no importa lo compleja que pueda ser, y a continuacin utilizar
esta descripcin en un programa.
El elemento clave de la POO es la clase. Una clase se puede definir como una descripcin abstracta de
un grupo de objetos, cada uno de los cuales se diferencia por su estado especfico y por la posibilidad
de realizar una serie de operaciones. Por ejemplo, una lapicera es un objeto que tiene un estado (llena
de tinta o vaca) y sobre la cual se pueden realizar algunas operaciones (escribir, recargar la tinta,
poner o quitar capuchn).
La idea de escribir programas definiendo una serie de abstracciones no es nueva, pero el uso de clases
para gestionar dichas abstracciones en lenguajes de programacin ha facilitado considerablemente su
aplicacin.
Encapsulacin
La encapsulacin o encapsulamiento es la propiedad que permite asegurar que el contenido de la
informacin de un objeto esta oculta al mundo exterior: el objeto A no conoce lo que hace el objeto B,
y viceversa. La encapsulacin (tambin se conoce como ocultamiento de la informacin), en esencia,
es el proceso de ocultar todos los secretos de un objeto que no contribuyen a sus caractersticas
esenciales.
La encapsulacin permite la divisin de un programa en mdulos, estos mdulos se implementan
mediante clases, de forma que una clase representa encapsulacin de una abstraccin.
Modularidad
La modularidad es la propiedad que permite subdividir una aplicacin en partes ms pequeas
(llamadas mdulos), cada una las cuales deben ser tan independientes como sea posible de la
aplicacin en s y de las restantes partes.
La modularizacin consiste en dividir un programa en mdulos que se puedan compilar por separado,
pero que tienen conexiones con otros mdulos. Al igual que la encapsulacin, los lenguajes soportan
la modularizacin de diferentes formas, en OO estos mdulos son las clases.
Carreras: Analista de Sistemas y Licenciatura en Sistemas
Asignatura: Resolucin de Problemas y Algoritmos
Docente: Lic. Vernica L. Vanoli
Apunte de Ctedra
- Pgina 87 de 165 -
Beneficios de la Orientacin a Objetos
La principal razn para desarrollar sistemas informticos OO sin lugar a dudas, son los beneficios de
esta tecnologa: aumento de la fiabilidad y productividad del desarrollador. La fiabilidad se puede
mejorar debido a que cada objeto es simplemente una caja negra con respecto a objetos externos
con los que debe comunicarse. Las estructuras de datos internas y mtodos se pueden refinar sin
afectar a otras partes de un sistema.
La productividad del desarrollador se puede mejorar debido a que las clases de objetos se pueden
hacer reutilizables de modo que en cada subclase o instancia de un objeto se puede utilizar el mismo
cdigo de programa para la clase. Por otra parte, esta productividad tambin aumenta debido a que
existe una asociacin ms natural entre objetos del sistema y objetos el mundo real.
METODOS
DATOS
OBJETO
El objeto como caja negra
Resumiendo, podemos decir que los principales beneficios de la OO son:
Reutilizacin.
Sistemas ms fiables.
Desarrollo ms rpido.
Desarrollo ms flexible.
Modelos que reflejan mejor la realidad.
Resultados de alta calidad.
Fcil mantenimiento.
Importante:
Cuando estamos desarrollando un sistema, el sistema se divide en clases. Cuando estamos ejecutando
un sistema, existe un conjunto de objetos que tienen la responsabilidad de realizar las diferentes
funciones del sistema.
Objetos
Carreras: Analista de Sistemas y Licenciatura en Sistemas
Asignatura: Resolucin de Problemas y Algoritmos
Docente: Lic. Vernica L. Vanoli
Apunte de Ctedra
- Pgina 88 de 165 -
Casi todo puede ser considerado un objeto. El dinero, el helicptero, una bicicleta, los perros, el auto.
Los objetos representan cosas, simples o complejas, reales o imaginarias. Una antena parablica es un
objeto complejo y real. Un objeto Profesor, representa los detalles y actividades de una persona, no es
esa persona en s misma, es pues, imaginario. Una frase, un nmero complejo, una receta y una cuenta
bancaria tambin son representaciones de cosas intangibles. Todas son objetos.
Algunas cosas no son objetos, sino atributos, valores o caractersticas de objetos. Es decir, no todas las
cosas son objetos, ni son consideradas normalmente como objetos. Algunas de ellas son simplemente
atributos de los objetos como el color, el tamao y la velocidad. Los atributos reflejan el estado de un
objeto, la velocidad del objeto avin, o el tamao de un objeto edificio. Normalmente no tiene sentido
considerar la velocidad como un objeto.
Algunas de las propiedades que se pueden aplicar a los objetos, tal como se han definido:
Los objetos son cosas.
Los objetos pueden ser simples o complejos.
Los objetos pueden ser reales o imaginarios.
El objeto mi auto
Para la discusin sobre objetos, se va a retomar el ejemplo de la introduccin y utilizar la definicin de
auto (automvil - coche) para definir algunos conceptos.
Para definir el objeto mi auto, hay que ser capaces de abstraer las funciones y atributos de un auto; es
decir, hay que ser capaz de definir auto en trminos de qu puede hacer y qu caractersticas lo
distinguen de otros objetos.
Abstraccin funcional
Funcionalmente, un auto puede realizar las siguientes acciones:
Ir.
Parar.
Girar a la derecha.
Girar a la izquierda.
Hay cosas que se saben que los autos hacen, pero el cmo lo hacen, la implementacin de ir, parar,
girar (a la derecha, a la izquierda) es irrelevante desde el punto del diseo. Esto es lo que se conoce
como abstraccin funcional.
Abstraccin de datos
De forma semejante a la anterior, un auto tiene las siguientes caractersticas o atributos:
Color.
Velocidad.
Tamao.
Precio.
La manera en que se almacenan o definen esos atributos, tambin es irrelevante para el diseo del
objeto. Por ejemplo, el color puede definirse como la palabra rojo, o como un entero que representa el
nmero (1 para rojo, 2 para azul, etc.), o como un caracter (R para rojo, A para azul, etc.). La
forma en que el objeto almacena el atributo color es irrelevante para el programador. Este proceso de
despreocupacin de cmo se almacena el color es lo que se llama abstraccin de datos.
Carreras: Analista de Sistemas y Licenciatura en Sistemas
Asignatura: Resolucin de Problemas y Algoritmos
Docente: Lic. Vernica L. Vanoli
Apunte de Ctedra
- Pgina 89 de 165 -
Encapsulacin de objetos
Los objetos encapsulan sus operaciones y su estado, son islas de estado y comportamiento.
El comportamiento del objeto est definido por las operaciones
El estado est definido por los datos o atributos del objeto
Encapsulacin es el trmino de orientacin a objetos que describe la vinculacin de operaciones y el
estado a un objeto particular. La encapsulacin est ntimamente relacionada con la ocultacin de la
informacin, definiendo qu partes de un objeto son visibles y qu partes estn ocultas.
La encapsulacin abarca a la ocultacin de la informacin:
Algunas partes son visibles.
Otras partes son ocultas.
Por ejemplo: el volante de un auto representa una parte visible hacia el mecanismo de giro de un auto.
La implementacin del volante es oculta y sobre ella slo puede actuar el propio volante.
Qu ocurre si cambia la implementacin?.
Repitiendo, la encapsulacin es la agrupacin del estado y comportamiento para formar objetos, donde
algunas partes son visibles mientras que otras permanecen ocultas. La ventaja de la ocultacin de los
detalles de implementacin es que el objeto puede cambiar, y la visibilidad proporcionada puede ser
compatible con el original. Entonces los programas que utilizaban el objeto pueden seguir funcionando
sin alteracin alguna.
Esto es extremadamente til al modificar cdigo (ya que se restringe la propagacin de cambios).
Tambin se fomenta la reusabilidad, ya que el cdigo puede ser utilizado como una tecnologa de caja
negra (igual que los circuitos integrados en la industria electrnica). Y si se vuelve a pensar desde el
punto de vista econmico, esto viene a representar una ventaja de indudable valor.
Podemos decir entonces, que los objetos tienen determinadas caractersticas, que denominamos
propiedades. Estas propiedades son los atributos y los mtodos. Los atributos son caractersticas o
cualidades o datos del objeto. Los mtodos son el comportamiento propio del objeto (operaciones que
el objeto sabe hacer o hace). Adems, los atributos de un objeto slo pueden ser accedidos y
modificados por mtodos del mismo (encapsulacin).
Grficamente podemos representar al objeto mi auto de la siguiente manera:
Carreras: Analista de Sistemas y Licenciatura en Sistemas
Asignatura: Resolucin de Problemas y Algoritmos
Docente: Lic. Vernica L. Vanoli
Apunte de Ctedra
- Pgina 90 de 165 -
Objeto: mi auto
Atributos:
color : rojo
velocidad: 40
tamao: mediano
precio: 14000
Mtodos:
ir
parar
girar a la derecha
girar a la izquierda
Algo ltimo para rescatar, es que los principios de la definicin de objetos ayudan a los programadores
a hacer cdigo ms robusto, mantenible y seguro; porque se pueden aislar a cada uno de esos objetos y
tratarlo como un ente nico, con su propia personalidad, sin que haya cientos de caractersticas que
tengamos que tener presentes. Lo cual, desde el punto de vista econmico, que nunca hay que dejar de
tener presente, s resulta viable, ya que los objetos bien diseados pueden ser utilizados en muy
diversas aplicaciones, con lo cual el tiempo de desarrollo total se reduce.
Clases
Las clases representan el tipo de dato al que pertenecen los objetos, ya que en un programa un objeto
es una variable. Una clase define todas las propiedades (atributos y mtodos) que un objeto tendr.
Siguiendo el ejemplo del objeto mi auto, es obvio que la clase es Auto, ya que todos los autos tienen
las mismas propiedades (color, velocidad, tamao, precio, ... ir, parar, girar a la derecha o a la
izquierda, ...).
Una clase define un miembro real o una entidad abstracta. Es el tipo o clasificacin de datos. Una
clase define el comportamiento y atributos de un grupo de objetos de caractersticas similares.
Clase Auto
color, velocidad, tamao, precio
ir, parar, girar a der., girar a izq.
nombre de la clase
mtodos (funciones)
atributos (datos)
Un objeto es una instancia o variable de una clase. Se dice que pertenece a la clase. Un objeto se
distingue de otros miembros de la clase por sus atributos.
Una clase describe un conjunto de objetos con un comportamiento comn y atributos relacionados.
Una clase define datos (atributos) y operaciones (mtodos).
Carreras: Analista de Sistemas y Licenciatura en Sistemas
Asignatura: Resolucin de Problemas y Algoritmos
Docente: Lic. Vernica L. Vanoli
Apunte de Ctedra
- Pgina 91 de 165 -
Estructura de una clase
Formato general:
clase NombreDeLaClase
{
//declaracin de atributos
tipo_de_dato nombre_del_atributo1
tipo_de_dato nombre_del_atributo2
tipo_de_dato nombre_del_atributo3
.
.
.
tipo_de_dato nombre_del_atributoN
//definicin de mtodos
tipo_de_dato nombre_del_metodo1(tipo_de_dato parmetro1, tipo_de_dato parmetro2, ...)
{
//cuerpo del mtodo1
}
tipo_de_dato nombre_del_metodo2(tipo_de_dato parmetro1, tipo_de_dato parmetro2, ...)
{
//cuerpo del mtodo2
}
tipo_de_dato nombre_del_metodo3(tipo_de_dato parmetro1, tipo_de_dato parmetro2, ...)
{
//cuerpo del mtodo3
}
.
.
.
tipo_de_dato nombre_del_metodoN(tipo_de_dato parmetro1, tipo_de_dato parmetro2, ...)
{
//cuerpo del mtodo N
}
}
Como puede apreciarse los mtodos tienen el mismo formato que las funciones. De hecho, los
mtodos son funciones, es decir, tienen todas las propiedades de las mismas.
Convenciones:
1. El nombre de la clase va en forma completa y el comienzo de cada palabra en mayscula.
Ejemplo: NumerosEnteros.
2. El nombre de los mtodos va en forma completa y el comienzo de cada palabra, menos la primera,
en mayscula. Ejemplo: sumarNumerosEnteros.
3. El tipo de dato va en minscula. Ejemplo: entero.
4. El nombre de los atributos va en minscula. Ejemplo: color.
Carreras: Analista de Sistemas y Licenciatura en Sistemas
Asignatura: Resolucin de Problemas y Algoritmos
Docente: Lic. Vernica L. Vanoli
Apunte de Ctedra
- Pgina 92 de 165 -
Veamos el ejemplo: Clase Auto.
clase Auto
{
//declaracin de atributos
caracter color
entero velocidad
caracter tamao
real precio
//definicin de mtodos
ir()
{
escribir Andando el auto
retornar
}
parar()
{
escribir Deteniendo el auto
retornar
}
girarDerecha()
{
escribir Girando a la derecha el auto
retornar
}
girarIzquierda()
{
escribir Girando a la izquierda el auto
retornar
}
}
Veamos ahora, un uso de la clase.
{
principal UsoClaseAuto
{
//declaracin de objetos
Auto MI_AUTO, TU_AUTO
//creacin de los objetos
MI_AUTO = nuevo Auto()
TU_AUTO = nuevo Auto()
//mensajes a los objetos
MI_AUTO.ir()
Carreras: Analista de Sistemas y Licenciatura en Sistemas
Asignatura: Resolucin de Problemas y Algoritmos
Docente: Lic. Vernica L. Vanoli
Apunte de Ctedra
- Pgina 93 de 165 -
MI_AUTO.girarIzquierda()
MI_AUTO.ir()
MI_AUTO.girarDerecha()
MI_AUTO.ir()
MI_AUTO.parar()
.
.
.
TU_AUTO.ir()
TU_AUTO.parar()
.
.
.
}
}
En este ejemplo, se distingue en forma separada la declaracin de la creacin de los objetos.
En el caso de los objetos, a diferencia de los tipos de datos simples, el manejo de almacenamiento en
memoria es distinto. Cuando se declara la variable, slo se asigna un espacio en memoria para el
identificador (MI_AUTO o TU_AUTO), y en el momento que se crea el objeto con la sentencia
NUEVO se asigna el espacio en memoria necesario para almacenar los atributos (color, velocidad,...)
del objeto que se est creando. En consecuencia, si un objeto no se crea, no se puede usar. En este
caso, declaracin y creacin son diferentes.
Mensajes
Un mensaje es la forma disponible para solicitar a un objeto que ejecute o realice un mtodo.
Formato general:
nombre_del_objeto.nombre_del_mtodo(variable1, variable2, ...)
Por ejemplo:
MI_AUTO.ir()
MI_AUTO.girarIzquierda()
En el caso de que el mtodo al que se le est enviando un mensaje requiera parmetros, el mensaje
debe cumplir con la correspondencia de parmetros (nmero, orden y tipo) con el mtodo.
Constructor
El constructor es un mtodo que tienen todas las clases, aunque no se implemente. Este mtodo es el
que se ejecuta, cuando se crea el objeto con la sentencia nuevo. Bsicamente, la tarea del constructor
es la asignacin de espacio en memoria adecuado para el objeto que se est creando y la inicializacin
con valores a los atributos del objeto.
Si el constructor se implementa debe llevar siempre el mismo nombre de la clase, puede tener o no
parmetros y nunca devuelve nada.
Carreras: Analista de Sistemas y Licenciatura en Sistemas
Asignatura: Resolucin de Problemas y Algoritmos
Docente: Lic. Vernica L. Vanoli
Apunte de Ctedra
- Pgina 94 de 165 -
Veamos un ejemplo con la clase Auto:
clase Auto
{
//declaracin de atributos
caracter color
entero velocidad
caracter tamao
real precio
//constructor
Auto(caracter COL, entero VEL, caracter TAM, real PRE)
{
color COL
velocidad VEL
tamao TAM
precio PRE
}
//definicin de mtodos
ir()
{
escribir Andando el auto
retornar
}
parar()
{
escribir Deteniendo el auto
retornar
}
girarDerecha()
{
escribir Girando a la derecha el auto
retornar
}
girarIzquierda()
{
escribir Girando a la izquierda el auto
retornar
}
}
Como vemos, cuando se crea una instancia de la clase Auto, lo primero que se ejecuta es el mtodo
Constructor llamado Auto.
Si el mtodo constructor no se implementa, slo se asignar espacio en memoria adecuado para el
objeto que se est creando y se asignan valores por defectos a los atributos (0 para los enteros, 0.0 para
los reales, espacio vaco para los caracteres y falso para los booleanos). Por lo tanto, la creacin del
objeto ahora es diferente, veamos el siguiente ejemplo de constructor:
Carreras: Analista de Sistemas y Licenciatura en Sistemas
Asignatura: Resolucin de Problemas y Algoritmos
Docente: Lic. Vernica L. Vanoli
Apunte de Ctedra
- Pgina 95 de 165 -
{
principal EjemploConstructor
{
//declaracin de variables
caracter COLO, TAMA
entero VELO
real PREC
//declaracin del objeto
Auto MI_AUTO, TU_AUTO
//carga de los datos
escribir Ingrese el color del auto
leer COLO
escribir Ingrese la velocidad del auto
leer VELO
escribir Ingrese el tamao del auto
leer TAMA
escribir Ingrese el precio del auto
leer PREC
//creacin del objeto
MI_AUTO = nuevo Auto(COLO, VELO, TAMA, PREC)
//mensajes a los objetos
MI_AUTO.ir()
MI_AUTO.girarIzquierda()
MI_AUTO.ir()
MI_AUTO.girarDerecha()
MI_AUTO.ir()
MI_AUTO.parar()
.
.
.
}
}
Acceso a los atributos
Retomando el ejemplo de la clase Auto, cuyos atributos son color, velocidad, tamao y precio, y cuyos
mtodos son ir(), parar(), girarDerecha() y girarIzquierda(), supongamos el caso en que un objeto auto
en particular como MI_AUTO se desee vender, para ello ser necesario conocer el precio. Puede
ocurrir tambin que el auto aumente su valor, por consecuencia necesitaremos cambiar el precio del
mismo. Si el auto adquiere otro color de pintura, entonces ser necesario cambiarle el color. Y as,
realizar ciertas operaciones que requieran acceder a los atributos. Pero con los mtodos que tenemos
no podemos hacerlo, necesitamos una forma que nos permita modificar los valores de los atributos,
como as tambin obtener los valores.
Dado que los datos de un objeto no se pueden acceder directamente, es necesario tener mtodos de
acceso a los atributos.
Carreras: Analista de Sistemas y Licenciatura en Sistemas
Asignatura: Resolucin de Problemas y Algoritmos
Docente: Lic. Vernica L. Vanoli
Apunte de Ctedra
- Pgina 96 de 165 -
Por ejemplo:
real obtenerPrecio()
{
retornar precio
}
modificarPrecio(real PREC)
{
precio PREC
retornar
}
Estos dos mtodos aseguran que slo el objeto accede a sus datos.
Por otra parte, si tenemos lo siguiente:
Real obtenerPrecio()
{
retornar precio
}
mostrarPrecio()
{
escribir precio
retornar
}
La diferencia radica en que, a travs del primer mtodo, el objeto devuelve el valor del atributo precio
y en el principal, mediante una variable (que toma ese valor), se puede realizar todas las operaciones
que desee, como hacer clculos, comparar con otros precios, e inclusive mostrar el valor. Esta ltima
operacin la realiza el segundo mtodo, que slo muestra el precio y no da la posibilidad de
manipularlo.
mbito de un identificador
Si tenemos una clase A, que posee un identificador ident declarado de diferentes formas (atributo,
variable o parmetro) en la clase, el identificador ident representar distintos datos segn el lugar que
est referenciando dentro de la clase. Es decir, se est designando a diferentes datos, de acuerdo a las
reglas de mbito.
As mismo, puesto que usar los mismos nombres de identificador para designar atributos, variables y
parmetros, pueden ocasionar confusin; es importante tener en cuenta las reglas de mbito de
identificadores:
Un atributo puede ser utilizado en cualquier mtodo de la clase.
Si en el mtodo M existe declarada la variable ident y en la misma clase existe el atributo ident, al
referenciar en M al identificador ident, se estar haciendo referencia a la variable y no al atributo.
Si en el mtodo M existe declarado un parmetro ident y en la misma clase existe el atributo ident,
al referenciar en M al identificador ident, se estar haciendo referencia al parmetro y no al
atributo.
Carreras: Analista de Sistemas y Licenciatura en Sistemas
Asignatura: Resolucin de Problemas y Algoritmos
Docente: Lic. Vernica L. Vanoli
Apunte de Ctedra
- Pgina 97 de 165 -
Las variables y parmetros declarados en el mtodo M son locales al mtodo, por lo tanto, no
pueden usarse fuera del mismo.
En el mtodo M no pueden declararse variables locales y parmetros con el mismo nombre de
identificador.
clase A
{
entero ident1
real ident2
A()
{
ident1... //se referencia al atributo ident1 de la clase
ident2... //se referencia al atributo ident2 de la clase
}
metodoUno()
{
ident1... //se referencia al atributo ident1 de la clase
}
metodoDos(entero ident1)
{
ident1... //se referencia al parmetro ident1 del metodoDos
ident2... //se referencia al atributo ident2 de la clase
}
metodoTres()
{
entero ident1
ident1... //se referencia a la variable local ident1 del metodoTres
ident2... //se referencia al atributo ident2 de la clase
}
metodoCuatro(real ident2)
{
entero ident1
ident1... //se referencia a la variable local ident1 del metodoCuatro
ident2... //se referencia al parmetro ident2 del metodoCuatro
}
}
Reuso del Cdigo
Un tipo de dato se compone de un conjunto de valores y una serie de operaciones permitidas que se
pueden aplicar a esos datos. As tenemos que cuando declaramos una variable del tipo de dato entero,
esta podr asumir un valor de un rango previamente establecido y sobre la misma se podrn aplicar
determinadas operaciones (suma, resta, modulo, divisin, producto, asignacin, comparaciones). A
diferencia de una variable de tipo de dato caracter, que asume otros valores y otras operaciones.
Carreras: Analista de Sistemas y Licenciatura en Sistemas
Asignatura: Resolucin de Problemas y Algoritmos
Docente: Lic. Vernica L. Vanoli
Apunte de Ctedra
- Pgina 98 de 165 -
La gran ventaja de trabajar con tipos de datos, es que el programador solo debe saber:
El conjunto de valores que puede asumir.
Las operaciones permitidas.
Y desconoce totalmente todo detalle de implementacin interna. Es decir, como se representa
internamente al entero o como realiza la adicin, es algo que el programador no necesita saber
para usar variables de tipo entero. Es decir, los detalles internos estn encapsulados.
Por otro lado, al tener el tipo de dato entero definido puede usarlo en tantos programas como desea
y necesita.
Lo mismo ocurre con las clases. Las clases son tipos de datos que crea el programador. Una vez que la
clase esta programada y probada, podr ser usada en muchos programas sin necesidad que quin la
usa, conozca sus detalles internos.
Clase Vector
Una clase define datos (atributos) y operaciones (mtodos). As podemos tener una clase Vector, que
represente a un arreglo de una dimensin y ofrezca operaciones tales como: agregar un elemento,
buscar un elemento, mostrar el vector, etc. La ventaja seria que los programas que usen esta clase, por
ejemplo no debern manejar ndices, testeos, bucles y otras operaciones tpicas de vectores.
Veamos el formato bsico de la clase Vector.
clase Vector
{
entero [ ] elementos //elementos del vector
entero dimension, actual //tamao asignado por el usuario y tamao real del vector
//constructor para la clase vector
Vector(entero TAMAO)
{
si (TAMAO <= 0)
dimension 100
sino
dimension TAMAO
actual 0
elementos = nuevo entero [dimension]
}
//mtodo que agrega de un elemento
//precondicin: elemento entero
//postcondicin: valor agregado si hay lugar en el vector
agregarElemento(entero VALOR)
{
si (actual < dimension)
{
elementos[actual] VALOR
actual actual + 1
}
retornar
}
Carreras: Analista de Sistemas y Licenciatura en Sistemas
Asignatura: Resolucin de Problemas y Algoritmos
Docente: Lic. Vernica L. Vanoli
Apunte de Ctedra
- Pgina 99 de 165 -
//mtodo que muestra el contenido del vector
//precondicin: vector con elementos
//postcondicin: muestreo de los elementos del vector
mostrarVector()
{
entero CONT
para (CONT 0; CONT < actual; CONT CONT + 1)
escribir elementos[CONT]
retornar
}
}
La diferencia entre los atributos dimension y actual, es cunto se va a reservar de memoria para
guardar el vector (dimension) y cunto se puede de esa cantidad usar en realidad (actual). Esto se debe
a la flexibilidad del mtodo de agregado de elementos, que va de uno en uno.
Como se ha dicho anteriormente, una funcin (mtodo) no puede realizar lecturas dentro de ella. Por
lo tanto, es necesario contar con un mtodo que incorpore los elementos de a uno. De all surge el
agregarElementos(entero). Una variante del mtodo agregarElementos(entero) es para los casos
donde el atributo actual supere el tamao del vector. Sera incorporar una variable de tipo booleano
que avise si se ha cargado o no el elemento. Si bien este mtodo puede ser til, el mismo est
realizando ms de una accin, desventaja para el mtodo.
booleano agregarElementos(entero VALOR)
{
booleano AGREGO
si (actual < dimension)
{
elementos[actual] VALOR
actual actual + 1
AGREGO verdadero
}
sino
AGREGO falso
retornar AGREGO
}
Hay que tener en cuenta que la clase presentada slo se aplica a los vectores cuyos elementos son
enteros, habra que adaptarla al resto de los tipos de datos posibles. En consecuencia, debera ser clases
distintas y los nombres ayudaran para ver la diferencia, por ejemplo: VectorEnteros,
VectorCaracteres, etc.
La ventaja de crear la clase Vector seria que los programas que la usen, no debern manejar
operaciones inherentes a los vectores, slo usarlos. A continuacin se muestra un programa que hace
uso de la clase Vector, creando dos instancias de la misma, de igual dimensin.
{
principal UsaClaseVector
{
//declaracin de variables
Carreras: Analista de Sistemas y Licenciatura en Sistemas
Asignatura: Resolucin de Problemas y Algoritmos
Docente: Lic. Vernica L. Vanoli
Apunte de Ctedra
- Pgina 100 de 165 -
Vector OBJVECT1, OBJVECT2
entero DIM, CONT, ELEM
//carga de la dimensin
escribir Ingrese la dimensin de los vectores
leer DIM
//creacin del primer vector
OBJVECT1 = nuevo Vector(DIM)
//creacin del segundo vector
OBJVECT2 = nuevo Vector(DIM)
//carga del primer vector en su totalidad
escribir Carga de elementos del primer vector
para (CONT 0; CONT < DIM; CONT CONT + 1)
{
escribir Ingresar un elemento
leer ELEM
OBJVECT1.agregarElementos(ELEM)
}
//carga del segundo vector en su totalidad
escribir Carga de elementos del segundo vector
para (CONT 0; CONT < DIM; CONT CONT + 1)
{
escribir Ingresar un elemento
leer ELEM
OBJVECT2.agregarElementos(ELEM)
}
//muestra del primer vector
escribir Primer vector resultante
OBJVECT1.mostrarVector()
//muestra del segundo vector
escribir Segundo vector resultante
OBJVECT2.mostrarVector()
}
}
En este programa UsaClaseVector hemos usado la clase Vector como un tipo de datos mas, como el
tipo entero. La carga y muestra de los elementos no se codifican en cada programa donde se usan
vectores, sino que estas operaciones al estar incluidas como mtodos en la clase Vector y estos
programas al trabajar con objetos de la misma clase, reusan el cdigo ya escrito en la misma. Esta es
una de las formas de Reusar Cdigo, principal caracterstica de la Programacin Orientada a Objetos.
Tanto la carga como la muestra del vector, son actividades constantes en el uso de los mismos. Pero,
existen otras operaciones que varan de acuerdo al problema a desarrollar. Por ejemplo, una vez
cargado el vector se puede hallar la suma de sus elementos. Veamos el mtodo con dicha operacin
que deber agregado a la clase Vector.
Carreras: Analista de Sistemas y Licenciatura en Sistemas
Asignatura: Resolucin de Problemas y Algoritmos
Docente: Lic. Vernica L. Vanoli
Apunte de Ctedra
- Pgina 101 de 165 -
//suma de los elementos del vector
//precondicin: vector con elementos enteros
//postcondicin: suma entera de los elementos del vector
entero sumarElementos()
{
entero SUMA, IND
SUMA 0
para (IND 0; IND < actual; IND IND + 1)
SUMA SUMA + elementos[IND]
retornar SUMA
}
En este caso, con el bucle vamos recorriendo el vector, accediendo a cada elemento del mismo
mediante el ndice (IND), y acumulando los elementos en la variable SUMA.
Podemos incluir en el programa UsaClaseVector como un objeto vector suma sus elementos.
SUMATORIA OBJVECT1.sumarElementos()
escribir El resultado de la suma de los elementos del primer vector es, SUMATORIA
Ejemplos.
Problema: Agregar a la clase vector un mtodo que cuente cuntos elementos del vector son mltiplos
de 5.
clase Vector
{
.
.
.
//cantidad de mltiplos por 5
//precondicin: vector con elementos enteros
//postcondicin: cantidad entera de los elementos mltiplos de 5 del vector
entero contarMultiplosCinco()
{
entero CANT, POS
CANT 0
POS 0
hacer
{
si (elementos[POS] % 5 = = 0)
CANT CANT + 1
}
mientras (POS < actual)
retornar CANT
}
}
Carreras: Analista de Sistemas y Licenciatura en Sistemas
Asignatura: Resolucin de Problemas y Algoritmos
Docente: Lic. Vernica L. Vanoli
Apunte de Ctedra
- Pgina 102 de 165 -
Problema: A partir de un vector de caracteres ya cargado, reemplazar las vocales por el caracter *.
Tambin a una posicin determinada asignarle un espacio vaco. Probar la clase.
clase VectorCaracteres
{
caracter [ ] elementos
entero dimension, actual
VectorCaracteres(entero DIM)
{
.
.
.
elementos = nuevo caracter [dimension]
}
agregarElementos(caracter ELEM)
{
.
.
.
}
//reemplazo de vocales
//precondicin: vector con elementos caracteres
//postcondicin: vector modificado con las vocales reemplazadas por *
reemplazarVocales()
{
entero IND
para (IND 0; IND < actual; IND IND + 1)
si ((elementos[IND] >= a & elementos[IND] <= z) |
(elementos[IND] >= A & elementos[IND] <= Z))
elementos[IND] *
retornar
}
//reemplazo de una posicin determinada
//precondicin: vector con elementos caracteres y posicin entera vlida
//postcondicin: vector modificado en una posicin determinada por espacio vaco
reemplazarPosicion(entero POS)
{
si (POS >= 0 & POS < actual)
elementos[POS]
retornar
}
}
{
principal UsaVectorCaracteres
{
Carreras: Analista de Sistemas y Licenciatura en Sistemas
Asignatura: Resolucin de Problemas y Algoritmos
Docente: Lic. Vernica L. Vanoli
Apunte de Ctedra
- Pgina 103 de 165 -
//declaracin de variables
Vector OBJVECT
entero DIM, CONT, ELEM, POS
//carga de la dimensin
escribir Ingrese la dimensin del vector
leer DIM
//creacin del vector
OBJVECT = nuevo VectorCaracteres(DIM)
//carga del vector en su totalidad
escribir Carga del vector
para (CONT 0; CONT < DIM; CONT CONT + 1)
{
escribir Ingrese un elemento al vector
leer ELEM
OBJVECT.agregarElementos(ELEM)
}
//reemplazo de vocales por *
OBJVECT.reemplazarVocales()
//muestra del vector
escribir Vector resultante luego de reemplazar las vocales por *
OBJVECT.mostrarVector()
//reemplazo de una determinada posicin
escribir Ingrese una posicin que se reemplazar por un espacio vaco
leer POS
OBJVECT.reemplazarPosicion(POS)
//muestra del vector
escribir Vector resultante luego de reemplazar una determinada posicin por espacio vaco
OBJVECT.mostrarVector()
}
}
Dos detalles importantes que se estn descuidando son: qu ocurre si se ingresa un valor incorrecto
como dimensin desde el principal? qu ocurre con el vector original luego de realizar el primer
reemplazo?. Analizarlo y actualizar si es necesario!!!.
Es importante aclarar que la clase debe proteger a sus atributos y sus mtodos no deben fallar, por lo
tanto, se debe realizar la mayor cantidad de testeos o validaciones posibles dentro de la clase. Esto no
quiere decir que en el principal no puedan realizarse testeos. Pero la realidad es que existe una sola
clase y varios principales que la usan, por lo tanto, es muy difcil asegurarnos de que todos los
principales hagan lo mismo.
Clase Matriz
De la misma manera que podemos crear la clase Vector, tambin podemos contar con una clase Matriz
que contenga todo lo referido a un arreglo de dos dimensiones.
Carreras: Analista de Sistemas y Licenciatura en Sistemas
Asignatura: Resolucin de Problemas y Algoritmos
Docente: Lic. Vernica L. Vanoli
Apunte de Ctedra
- Pgina 104 de 165 -
Veamos el formato bsico de la clase Matriz.
clase Matriz
{
entero [ ][ ] elementos //elementos de la matriz
entero dimensionfila, dimensioncolumna //tamao asignado por el usuario
entero actualfila, actualcolumna //tamao real de la matriz
//constructor para la clase matriz
Matriz(entero DIMF, entero DIMC)
{
si (DIMF <= 0 | DIMC <= 0)
{
dimensionfila 9
dimensioncolumna 11
}
sino
{
dimensionfila DIMF
dimensioncolumna DIMC
}
actualfila 0
actualcolumna 0
elementos = nuevo entero [dimensionfila][dimensioncolumna]
}
//mtodo que agrega de un elemento
//precondicin: elemento entero
//postcondicin: valor agregado si hay lugar en la matriz
agregarElementos(entero VALOR)
{
elementos[actualfila][actualcolumna] VALOR
si (actualcolumna = = dimensioncolumna - 1)
{
actualcolumna 0
actualfila actualfila + 1
}
sino
actualcolumna actualcolumna + 1
si (actualfila = = dimensionfila)
actualcolumna dimensioncolumna
retornar
}
//mtodo que muestra el contenido de la matriz
//precondicin: matriz con elementos
//postcondicin: muestreo de los elementos de la matriz
mostrarMatriz()
{
Carreras: Analista de Sistemas y Licenciatura en Sistemas
Asignatura: Resolucin de Problemas y Algoritmos
Docente: Lic. Vernica L. Vanoli
Apunte de Ctedra
- Pgina 105 de 165 -
entero FIL, COL
para (FIL 0; FIL < actualfila; FIL FIL + 1)
para (COL 0; COL < actualcolumna; COL COL + 1)
escribir elementos[FIL][COL]
retornar
}
}
Lo mismo que se ha visto en la clase Vector, este formato es para matrices con elementos enteros, por
lo tanto, si los elementos fueran de otro tipo, deberamos adaptar la matriz, como por ejemplo:
MatrizEnteros, MatrizCaracteres, etc. Adems, como se puede apreciar, la clase trabaja con una
matriz no cuadrada. Sabemos muy bien que existen operaciones que slo pueden ser aplicadas a
matrices cuadradas, por lo tanto, para qu tener que controlar esto en cada mtodo. Entonces, sera
recomendable contar con otra clase que slo trabaje con este tipo de matrices. De esta manera, no es
necesario contar con dos dimensiones como atributos de la matriz. As, nos quedaran ejemplos como:
MatrizNoCuadradaEnteros, MatrizNoCuadradaCaracteres, MatrizCuadradaEnteros,
MatrizCuadradaCaracteres, etc.
Ejemplos.
Problema: Multiplicar los elementos de una matriz.
clase Matriz
{
entero [ ][ ] elementos
entero dimensionfila, dimensioncolumna
entero actualfila, actualcolumna
.
.
.
//producto de los elementos de la matriz
//precondicin: matriz con elementos enteros
//postcondicin: producto entero de los elementos de la matriz
entero multiplicarElementos()
{
entero PRODUCTO, POSF, POSC
PRODUCTO 1
para (POSF 0; POSF < actualfila; POSF POSF + 1)
para (POSC 0; POSC < actualcolumna; POSC POSC + 1)
PRODUCTO PRODUCTO * elementos[POSF][POSC]
retornar PRODUCTO
}
}
Problema: Hacer un mtodo que imprima los elementos de una columna determinada.
//muestra de una determinada columna de la matriz
//precondicin: matriz con elementos y nmero de columna vlido
Carreras: Analista de Sistemas y Licenciatura en Sistemas
Asignatura: Resolucin de Problemas y Algoritmos
Docente: Lic. Vernica L. Vanoli
Apunte de Ctedra
- Pgina 106 de 165 -
//postcondicin: muestreo de los elementos enteros de la columna ingresada
mostrarColumna(entero COLMOS)
{
entero FIL
si (COLMOS >= 0 & COLMOS < actualcolumna)
para (FIL 0; FIL < actualfila; FIL FIL + 1)
escribir elementos[FIL][COLMOS]
retornar
}
Problema: Dada una matriz de nmeros reales generar un vector donde cada elemento del mismo es el
elemento ms grande de cada columna de la matriz. Realizar el programa que pruebe la clase.
Veamos como ejemplo la siguiente Matriz:
3.4 6.0 4.6 8.8
0.9 4.9 1.1 3.9
4.3 0.1 7.4 8.0
El resultado sera el siguiente Vector:
4.3 6.0 7.4 8.8
clase Matriz
{
real [ ][ ] elementos
entero dimensionfila, dimensioncolumna
entero actualfila, actualcolumna
Matriz(entero DIMF, entero DIMC)
{
.
.
.
elementos = nuevo real [dimensionfila][dimensioncolumna]
}
agregarElementos(real VALOR)
{
.
.
.
}
//generacin del vector con los elementos mayores de cada columna
//precondicin: matriz con elementos reales
//postcondicin: vector con los elementos mayores de cada columna de la matriz
real [ ] elementosMayoresColumnas()
{
entero POSF, POSC
real MAYOR
real [ ] VECTOR = nuevo real [actualcolumna]
Carreras: Analista de Sistemas y Licenciatura en Sistemas
Asignatura: Resolucin de Problemas y Algoritmos
Docente: Lic. Vernica L. Vanoli
Apunte de Ctedra
- Pgina 107 de 165 -
para (POSC 0; POSC < actualcolumna; POSC POSC + 1)
{
MAYOR elementos[0][POSC]
para (POSF 1; POSF < actualfila; POSF POSF + 1)
si (elementos[POSF][POSC] > MAYOR)
MAYOR elementos[POSF][POSC]
VECTOR[POSC] MAYOR
}
retornar VECTOR
}
}
{
principal UsaClaseMatriz
{
//declaracin de variables
Matriz OBJMAT
entero FILAS, COLUMNAS
real [ ] VECTOR
entero CONTF, CONTC, CONT
real ELEM
//carga de las dimensiones
escribir Ingrese la cantidad de filas para la matriz
leer FILAS
escribir Ingrese la cantidad de columnas para la matriz
leer COLUMNAS
//creacin de la matriz
OBJMAT = nuevo Matriz(FILAS, COLUMNAS)
//carga de la matriz en su totalidad
escribir Carga de los elementos de la matriz
para (CONTF 0; CONTF < FILAS; CONTF CONTF + 1)
para (CONTC 0; CONTC < COLUMNAS; CONTC CONTC + 1)
{
escribir Ingrese un elemento para la posicin, CONTF, y , CONTC
leer ELEM
OBJMAT.agregarElementos(ELEM)
}
//muestra de la matriz
escribir La matriz resultante es
OBJMAT.mostrarMatriz()
//creacin y carga del vector para mostrar los elementos mayores de cada columna de la matriz
VECTOR = nuevo real [COLUMNAS]
VECTOR OBJMAT.elementosMayoresColumnas()
Carreras: Analista de Sistemas y Licenciatura en Sistemas
Asignatura: Resolucin de Problemas y Algoritmos
Docente: Lic. Vernica L. Vanoli
Apunte de Ctedra
- Pgina 108 de 165 -
//muestra del vector
escribir Vector con los elementos ms grandes de cada columna de la matriz
para (CONT 0; CONT < COLUMNAS; CONT CONT + 1)
escribir VECTOR[CONT]
}
}
En este caso, la clase Matriz contiene el mtodo elementosMayoresColumnas() que devuelve un
vector. Esto no quiere decir que la clase matriz deba contener mtodos que manipulen dicho vector,
como por ejemplo, mostrar el vector. La clase Matriz, slo maneja cuestiones relacionadas a matrices.
Es por eso, que en este caso, el principal se hace cargo de crear un vector vaco, obtener el vector
resultante y mostrarlo. Este proceso se puede mejorar haciendo un buen uso de los objetos. Es decir, el
principal, creara un objeto (instancia) de la clase Matriz y un objeto de la clase Vector, entonces la
tarea de mostrar el vector, la tendra la clase Vector y no el principal.
Recordemos que hasta el momento estamos trabajando con una sola clase (es decir, el principal slo
crea objetos de una sola clase), pero cuando el problema a resolver sea an mayor, seguramente nos
veremos obligados a trabajar con ms de una clase. Esto ocurre normalmente con los Sistemas.
Carreras: Analista de Sistemas y Licenciatura en Sistemas
Asignatura: Resolucin de Problemas y Algoritmos
Docente: Lic. Vernica L. Vanoli
Apunte de Ctedra
- Pgina 109 de 165 -
LENGUAJE DE PROGRAMACION: JAVA
Java fue creado por la empresa Sun Microsystem en el ao 1995. En sus comienzos fue pensado para
pequeos procesadores incorporados en electrodomsticos (lavarropas, televisores, etc.) pero dicho
proyecto fracas. Con el auge de Internet rpidamente se noto un importante problema: las diferentes
plataformas o arquitecturas (hardware y sistemas operativos). Por lo tanto, Sun se propone crear un
lenguaje de programacin cuyos programas se ejecutaran sin problemas en diferentes plataformas y de
propsito general pero con especial nfasis en el uso de redes.
Java es un lenguaje que tiene muchsimas ventajas pero la ms importante es que esta en permanente
evolucin. Las caractersticas principales que nos ofrece Java respecto a cualquier otro lenguaje de
programacin, son:
Es SIMPLE
Java ofrece toda la funcionalidad de un lenguaje potente, pero sin las caractersticas menos usadas y
ms confusas de stos. C++ es un lenguaje que adolece de falta de seguridad, pero C y C++ son
lenguajes ms difundidos, por ello, Java se dise para ser parecido a C++ y as facilitar un rpido y
fcil aprendizaje.
Java reduce en un 50% los errores ms comunes de programacin con lenguajes como C y C++ al
eliminar muchas de las caractersticas de stos, entre las que destacan:
- aritmtica de punteros.
- no existen referencias.
- registros (struct).
- definicin de tipos (typedef).
- macros (#define).
- necesidad de liberar memoria (free).
Adems, el intrprete completo de Java que hay en este momento es muy pequeo, solamente ocupa
215 Kb de RAM.
Es ORIENTADO A OBJETOS
Java implementa la tecnologa OO con algunas mejoras y elimina algunas cosas para mantener el
objetivo de la simplicidad del lenguaje. Java trabaja con sus datos como objetos y con interfaces a esos
objetos. Soporta las tres caractersticas propias del paradigma de la orientacin a objetos:
encapsulacin, herencia y polimorfismo. Las plantillas de objetos son llamadas clases y sus copias,
instancias. Estas instancias, necesitan ser construidas y destruidas en espacios de memoria.
Es DISTRIBUIDO
Java se ha construido con extensas capacidades de interconexin TCP/IP. Existen libreras de rutinas
para acceder e interactuar con protocolos como http y ftp. Esto permite a los programadores acceder a
la informacin a travs de la red con tanta facilidad como a los ficheros locales.
Es ROBUSTO
Java realiza verificaciones en busca de problemas tanto en tiempo de compilacin como en tiempo de
ejecucin. La comprobacin de tipos en Java ayuda a detectar errores, lo antes posible, en el ciclo de
desarrollo. Java obliga a la declaracin explcita de mtodos, reduciendo as las posibilidades de error.
Maneja la memoria para eliminar las preocupaciones por parte del programador de la liberacin o
corrupcin de memoria. Tambin implementa los arrays (arreglos) autnticos, en vez de listas
enlazadas de punteros, con comprobacin de lmites, para evitar la posibilidad de sobreescribir o
Carreras: Analista de Sistemas y Licenciatura en Sistemas
Asignatura: Resolucin de Problemas y Algoritmos
Docente: Lic. Vernica L. Vanoli
Apunte de Ctedra
- Pgina 110 de 165 -
corromper memoria, resultado de punteros que sealan a zonas equivocadas. Estas caractersticas
reducen drsticamente el tiempo de desarrollo de aplicaciones en Java.
Adems, para asegurar el funcionamiento de la aplicacin, realiza una verificacin de los byte-codes,
que son el resultado de la compilacin de un programa Java. Es un cdigo de mquina virtual que es
interpretado por el intrprete Java. No es el cdigo mquina directamente entendible por el hardware,
pero ya ha pasado todas las fases del compilador: anlisis de instrucciones, orden de operadores, etc., y
ya tiene generada la pila de ejecucin de rdenes.
Entonces Java proporciona:
- Comprobacin de punteros.
- Comprobacin de lmites de arrays.
- Excepciones.
- Verificacin de byte-codes.
Es PORTABLE
Ms all de la portabilidad bsica por ser de arquitectura independiente, Java implementa otros
estndares de portabilidad para facilitar el desarrollo. Los enteros son siempre enteros y adems,
enteros de 32 bits en complemento a 2. Adems, Java construye sus interfaces de usuario a travs de
un sistema abstracto de ventanas de forma que las ventanas puedan ser implantadas en entornos Unix,
Pc o Mac.
Es SEGURO
La seguridad en Java tiene dos facetas. En el lenguaje, caractersticas como los punteros o el casting
implcito que hacen los compiladores de C y C++ se eliminan para prevenir el acceso ilegal a la
memoria. Cuando se usa Java para crear un navegador, se combinan las caractersticas del lenguaje
con protecciones de sentido comn aplicadas al propio navegador.
El cdigo Java pasa muchos tests antes de ejecutarse en una mquina. El cdigo se pasa a travs de un
verificador de byte-codes que comprueba el formato de los fragmentos de cdigo y aplica un probador
de teoremas para detectar fragmentos de cdigo ilegal (cdigo que falsea punteros, viola derechos de
acceso sobre objetos o intenta cambiar el tipo o clase de un objeto).
Si los byte-codes pasan la verificacin sin generar ningn mensaje de error, entonces sabemos que:
- El cdigo no produce desbordamiento de operandos en la pila.
- El tipo de los parmetros de todos los cdigos de operacin son conocidos y correctos.
- No ha ocurrido ninguna conversin ilegal de datos, tal como convertir enteros en punteros.
- El acceso a los campos de un objeto se sabe que es legal: public, private, protected.
- No hay ningn intento de violar las reglas de acceso y seguridad establecidas.
El Cargador de Clases tambin ayuda a Java a mantener su seguridad, separando el espacio de
nombres del sistema de ficheros local, del de los recursos procedentes de la red. Esto limita cualquier
aplicacin del tipo Caballo de Troya, ya que las clases se buscan primero entre las locales y luego
entre las procedentes del exterior.
Las clases importadas de la red se almacenan en un espacio de nombres privado, asociado con el
origen. Cuando una clase del espacio de nombres privado accede a otra clase, primero se busca en las
clases predefinidas (del sistema local) y luego en el espacio de nombres de la clase que hace la
referencia. Esto imposibilita que una clase suplante a una predefinida.
En resumen, las aplicaciones de Java resultan extremadamente seguras, ya que no acceden a zonas
delicadas de memoria o del sistema, con lo cual evitan la interaccin de ciertos virus. Java no posee
una semntica especfica para modificar la pila de programa, la memoria libre o utilizar objetos y
mtodos de un programa sin los privilegios del kernel del sistema operativo. Adems, para evitar
modificaciones por parte de los crackers de la red, implementa un mtodo ultraseguro de
autentificacin por clave pblica. El Cargador de Clases puede verificar una firma digital antes de
Carreras: Analista de Sistemas y Licenciatura en Sistemas
Asignatura: Resolucin de Problemas y Algoritmos
Docente: Lic. Vernica L. Vanoli
Apunte de Ctedra
- Pgina 111 de 165 -
realizar una instancia de un objeto. Por lo tanto, ningn objeto se crea y almacena en memoria, sin que
se validen los privilegios de acceso. Es decir, la seguridad se integra en el momento de compilacin,
con el nivel de detalle y de privilegio que sea necesario.
Dada la concepcin del lenguaje y si todos los elementos se mantienen dentro del estndar marcado
por Sun, no hay peligro. Java imposibilita, tambin, abrir ningn fichero de la mquina local (siempre
que se realizan operaciones con archivos, stas trabajan sobre el disco duro de la mquina de donde
parti el applet), no permite ejecutar ninguna aplicacin nativa de una plataforma e impide que se
utilicen otros ordenadores como puente, es decir, nadie puede utilizar nuestra mquina para hacer
peticiones o realizar operaciones con otra. Adems, los intrpretes que incorporan los navegadores de
la Web son an ms restrictivos. Bajo estas condiciones (y dentro de la filosofa de que el nico
ordenador seguro es el que est apagado, desenchufado, dentro de una cmara acorazada en un bunker
y rodeado por mil soldados de los cuerpos especiales del ejrcito), se puede considerar que Java es un
lenguaje seguro y que los applets estn libres de virus.
Respecto a la seguridad del cdigo fuente, no ya del lenguaje, JDK (Java Developers Kit: Paquete de
Desarrollo para Java) proporciona un desemsamblador de byte-code, que permite que cualquier
programa pueda ser convertido a cdigo fuente, lo que para el programador significa una
vulnerabilidad total a su cdigo. Utilizando javap no se obtiene el cdigo fuente original, pero s
desmonta el programa mostrando el algoritmo que se utiliza, que es lo realmente interesante. La
proteccin de los programadores ante esto es utilizar llamadas a programas nativos, externos (incluso
en C o C++) de forma que no sea descompilable todo el cdigo; aunque as se pierda portabilidad. Esta
es otra de las cuestiones que Java tiene pendientes.
Es INTERPRETADO
El intrprete Java (sistema run-time) puede ejecutar directamente el cdigo objeto. Enlazar (linkar) un
programa, normalmente, consume menos recursos que compilarlo, por lo que los desarrolladores con
Java pasarn ms tiempo desarrollando y menos esperando por el ordenador. No obstante, el
compilador actual del JDK es bastante lento. Por ahora, que todava no hay compiladores especficos
de Java para las diversas plataformas, Java es ms lento que otros lenguajes de programacin, como
C++, ya que debe ser interpretado y no ejecutado como sucede en cualquier programa tradicional.
La verdad es que Java para conseguir ser un lenguaje independiente del sistema operativo y del
procesador que incorpore la mquina utilizada, es tanto interpretado como compilado. Y esto no es
ningn contrasentido; el cdigo fuente escrito con cualquier editor se compila generando el byte-code.
Este cdigo intermedio es de muy bajo nivel, pero sin alcanzar las instrucciones mquinas propias de
cada plataforma y no tiene nada que ver con el p-code de Visual Basic. El byte-code corresponde al
80% de las instrucciones de la aplicacin. Ese mismo cdigo es el que se puede ejecutar sobre
cualquier plataforma. Para ello, hace falta el run-time, que s es completamente dependiente de la
mquina y del sistema operativo, que interpreta dinmicamente el byte-code y aade el 20% de
instrucciones que faltaban para su ejecucin. Con este sistema es fcil crear aplicaciones
multiplataforma, pero para ejecutarlas es necesario que exista el run-time correspondiente al sistema
operativo utilizado.
Es de ARQUITECTURA NEUTRAL
Para establecer Java como parte integral de la red, el compilador Java compila su cdigo a un fichero
objeto de formato independiente de la arquitectura de la mquina en que se ejecutar. Cualquier
mquina que tenga el sistema de ejecucin (run-time) puede ejecutar ese cdigo objeto, sin importar
en modo alguno la mquina en que ha sido generado. Actualmente existen sistemas run-time para
Solaris 2.x, SunOs 4.1.x, Windows 95, Windows NT, Windows 2000, Windows XP, Linux, Irix, Aix,
Mac, Apple y probablemente haya grupos de desarrollo trabajando en el porting a otras plataformas.
Carreras: Analista de Sistemas y Licenciatura en Sistemas
Asignatura: Resolucin de Problemas y Algoritmos
Docente: Lic. Vernica L. Vanoli
Apunte de Ctedra
- Pgina 112 de 165 -
El cdigo fuente Java se compila a un cdigo de bytes de alto nivel independiente de la mquina.
Este cdigo (byte-codes) est diseado para ejecutarse en una mquina hipottica que es implementada
por un sistema run-time, que s es dependiente de la mquina.
Es MULTITHREADED
Al ser multithreaded (multihilo), Java permite muchas actividades simultneas en un programa. Los
threads (a veces llamados, procesos ligeros) son bsicamente pequeos procesos o piezas
independientes de un gran proceso. Al estar los threads construidos en el lenguaje, son ms fciles de
usar y ms robustos.
El beneficio de ser multithreaded consiste en un mejor rendimiento interactivo y mejor
comportamiento en tiempo real. Aunque el comportamiento en tiempo real est limitado a las
capacidades del sistema operativo subyacente (Unix, Windows, etc.) an supera a los entornos de flujo
nico de programa (single-threaded) tanto en facilidad de desarrollo como en rendimiento.
Cualquiera que haya utilizado la tecnologa de navegacin concurrente, sabe lo frustrante que puede
ser esperar por una gran imagen que se est abriendo. En Java, las imgenes se pueden ir abriendo en
un thread independiente, permitiendo que el usuario pueda acceder a la informacin en la pgina sin
tener que esperar por el navegador.
Es DINAMICO
Java se beneficia todo lo posible de la tecnologa orientada a objetos. Java no intenta conectar todos
los mdulos que comprenden una aplicacin hasta el tiempo de ejecucin. Las libreras API
(Application Programming Interface: Interfaz de Programacin de Aplicaciones) nuevas o actualizadas
no paralizarn las aplicaciones actuales (siempre que mantengan el API anterior).
Java tambin simplifica el uso de protocolos nuevos o actualizados. Si su sistema ejecuta una
aplicacin Java sobre la red y encuentra una pieza de la aplicacin que no sabe manejar, tal como se ha
explicado en prrafos anteriores, Java es capaz de bajar automticamente cualquiera de esas piezas que
el sistema necesita para funcionar.
Java, para evitar que los mdulos de byte-codes o los objetos o nuevas clases, haya que estar
bajndolos de la red cada vez que se necesiten, implementa las opciones de persistencia, para que no
se eliminen cuando se limpie la cach de la mquina.
De Pseudocdigo a Java
A continuacin veremos como sera el traspaso de todo lo visto hasta el momento, hecho en
pseudocdigo, al Lenguaje de Programacin Java.
Tipos de Datos Simples
Pseudocdigo Java Rango Descripcin
entero int 32-bit complemento a 2 Entero
entero byte 8-bit complemento a 2 Entero de 1 byte
entero short 16-bit complemento a 2 Entero corto
entero long 64-bit complemento a 2 Entero largo
real float 32-bit IEEE 754 Coma flotante de precisin simple
real double 64-bit IEEE 754 Coma flotante de precisin doble
caracter char 16-bit Caracter Un slo caracter
booleano boolean true o false Un valor booleano (verdadero o falso)
Declaracin de variables
Formato general:
Carreras: Analista de Sistemas y Licenciatura en Sistemas
Asignatura: Resolucin de Problemas y Algoritmos
Docente: Lic. Vernica L. Vanoli
Apunte de Ctedra
- Pgina 113 de 165 -
tipo_de_dato nombre_variable;
Por ejemplo:
char LETRA;
double MONTO;
int NUM, CONT;
boolean BANDERA;
El punto y coma (;) es un separador de sentencias. En Java, como en otros lenguajes, hay que indicar
explcitamente cuando termina una sentencia. Esto es as, porque no trata como especiales los cambios
de lnea.
Asignacin de variables
Formato general:
nombre_variable = valor;
Por ejemplo:
NUM=12;
CONT=CONT + 1;
LETRA=S
Declaracin de constantes
Formato general:
final tipo_de_dato nombre_constante = valor;
Por ejemplo:
final int TOPE=100;
final long PI=3.14;
Entrada de datos
Formato general:
nombre_variable = Console.readNombre_del_tipo_de_dato();
Por ejemplo:
De entero: VAR1=Console.readInt(); //VAR1 es una variable entera
De double: VAR2=Console.readDouble(); //VAR2 es una variable double
De cadenas: VAR3=Console.readString(); //VAR3 es una variable cadena de caracteres
Salida de datos
Formato general:
System.out.print(lista_de_expresiones_de_salida y/o mensaje_de_salida);
System.out.println(lista_de_expresiones_de_salida y/o mensaje_de_salida);
Por ejemplo:
System.out.println(Vector resultante); //se ver el mensaje escrito
System.out.println(RESULTADO); //se ver el contenido de la variable RESULTADO
System.out.println(El resultado de la suma es: +SUMA); //para mostrar un mensaje y una
//variable se utiliza el +
//(concatenacin)
System.out.print(El resultado de la suma es: );
System.out.print(SUMA); //produce el mismo resultado anterior
Carreras: Analista de Sistemas y Licenciatura en Sistemas
Asignatura: Resolucin de Problemas y Algoritmos
Docente: Lic. Vernica L. Vanoli
Apunte de Ctedra
- Pgina 114 de 165 -
//sacando ln para el salto de lnea
Tipo de dato de los resultados
Se ha visto anteriormente los resultados de aplicar los distintos operadores aritmticos con los tipos de
datos simples.
As por ejemplo:
int A, B, C;
double D;
A=5;
B=2;
C=A / B; //a la variable C se le asigna 2.
D=A / B; //a la variable D se le asigna 2.0 y no 2.5.
En todos estos casos, el lenguaje automticamente ha realizado una conversin de datos, por lo general
en el resultado de la operacin. Esta operacin se conoce como Cast Implcito.
Para que D sea 2.5 antes hay que realizar una conversin para A y/o B en double, esto se llama Cast
Explcito y lo realiza el programador usando (tipo_de_dato). Veamos como:
D=(double) A / (double) B; //los valores de A y B se convierten en double antes de efectuar
//la divisin, a D se le asigna 2.5
D=(double) A / B; //se logra el mismo efecto anterior, segn la tabla de conversin
D=(double) (A / B); //OJO!, en este caso, el resultado de la divisin se convierte en double,
//a D se le asigna 2.0.
Reglas:
Si los operandos de una operacin aritmtica son todos del mismo tipo, el resultado es del
mismo tipo.
Si los operandos de una operacin aritmtica son de diferentes tipos, se convierte el de tipo
ms pequeo al de tipo ms grande. Como el caso: D=(double) A / B D=5.0 / 2.
Conversiones:
N: no se pueden convertir.
A: conversin automtica.
C: conversin que requiere un cast.
A*: conversin automtica pero se pueden perder valores significativos.
Lase de izquierda a derecha (fila-columna)
boolean byte short char int long float double
boolean - N N N N N N N
byte N - A C A A A A
short N C - C A A A A
char N C C - A A A A
int N C C C - A A* A
long N C C C C - A* A*
float N C C C C C - A
double N C C C C C C -
Operaciones con contadores
A++; //A=A + 1;
A--; //A=A - 1;
Carreras: Analista de Sistemas y Licenciatura en Sistemas
Asignatura: Resolucin de Problemas y Algoritmos
Docente: Lic. Vernica L. Vanoli
Apunte de Ctedra
- Pgina 115 de 165 -
Pero si hacemos C=A++, dos variables modifican su valor, C y A.
Qu valor recibe C, el de A antes de incrementarse en 1 o el de A despus de incrementarse en 1?.
Probarlo.
Operaciones con acumuladores y otros
SUMA += NUM; //SUMA=SUMA + NUM;
PRODUCTO *= NUM; //PRODUCTO=PRODUCTO * NUM;
Lo mismo se puede aplicar para el resto de los operadores.
Operaciones lgicas
Operador Operacin Notas
! Negacin lgica Convierte un valor booleano en su contrario.
& Y lgico
Es verdadero, si y slo s, ambos operandos son
verdaderos. Se fuerza la evaluacin de los
operandos.
&& Y lgico
Igual que el anterior, pero permitiendo la
evaluacin incompleta de los operandos.
| O lgico Es falso, si y slo s, ambos operandos son falsos.
|| O lgico
Igual que el anterior, pero permitiendo la
evaluacin incompleta de los operandos.
Comentarios
// una lnea
/*....*/ un bloque
Como ejemplo del ltimo caso, podemos ver que todo lo que se encuentra encerrado en el bloque es
un comentario, por lo tanto, no se ejecuta.
/* int A, B, C;
A=5;
B=2;
C=A / B; */
Estructuras de Control en Java
El lenguaje Java soporta varias sentencias de control de flujo, incluyendo:
Seleccin
Pseudocdigo Java
si-sino if-else
alternar-caso switch-case
Veamos algunos ejemplos:
1. Para la sentencia if-else.
char RESPUESTA;
if(RESPUESTA = = S)
{
//cdigo para la accin S
}
Carreras: Analista de Sistemas y Licenciatura en Sistemas
Asignatura: Resolucin de Problemas y Algoritmos
Docente: Lic. Vernica L. Vanoli
Apunte de Ctedra
- Pgina 116 de 165 -
else
{
//cdigo para la accin N
}
2. Para la sentencia switch-case.
char COLOR; //colores primarios
switch(COLOR)
{
case R: {
System.out.println(Rojo);
break;
}
case A: {
System.out.println(Azul);
break;
}
case M: {
System.out.println(Amarillo);
break;
}
}
La sentencia switch evala la expresin (COLOR) y ejecuta la sentencia case apropiada. Decidir
cuando utilizar las sentencias if o switch depende del juicio personal. Se puede decidir cual utilizar
basndose en la buena lectura del cdigo o en otros factores. Cada sentencia case debe ser nica y el
valor proporcionado a cada sentencia case debe ser del mismo tipo que el tipo de dato devuelto por la
expresin proporcionada a la sentencia switch. La sentencia break hace que el control salga de la
sentencia switch y contine con la siguiente lnea. La sentencia break es necesaria porque las
sentencias case se siguen ejecutando hacia abajo. Esto es, sin un break explcito, el flujo de control
seguira secuencialmente a travs de las sentencias case siguientes. En el ejemplo anterior, no se
quiere que el flujo vaya de una sentencia case a otra, por eso se han tenido que poner las sentencias
break. Sin embargo, hay ciertos escenario en los que querrs que el control proceda secuencialmente a
travs de las sentencias case.
Se puede utilizar la sentencia default al final de la sentencia switch para manejar los valores que no se
han manejado explcitamente por una de las sentencias case.
switch(COLOR)
{
case R: {
System.out.println(Rojo);
break;
}
case A: {
System.out.println(Azul);
break;
}
case M: {
System.out.println(Amarillo);
Carreras: Analista de Sistemas y Licenciatura en Sistemas
Asignatura: Resolucin de Problemas y Algoritmos
Docente: Lic. Vernica L. Vanoli
Apunte de Ctedra
- Pgina 117 de 165 -
break;
}
default: {
System.out.println(No es un color primario!);
}
}
Iteracin
Pseudocdigo Java
mientras while
hacer-mientras do-while
para for
Veamos algunos ejemplos:
1. Bucle while.
int NUM;
NUM=Console.readInt(Ingrese un nmero: );
int CONT=0; //al mismo tiempo que se declara se le puede dar un valor de inicio
while(NUM != -1)
{
CONT++;
NUM=Console.readInt(Ingrese un nmero: );
}
System.out.println(La cantidad de nmeros ledos es: +CONT);
2. Bucle for.
//VEC es un arreglo de cualquier tipo
. . .
final int LONG=10;
for(int IND=0; IND < LONG; IND++)
{
//se realiza algo con cada elemento del arreglo VEC
}
3. Bucle do-while.
do
{
//se realiza algo que itere, teniendo en cuenta que al menos una vez se cumple
}
while (expresin de tipo booleano);
Reglas de sintaxis:
Todas las palabras reservadas van en minscula.
Se diferencian las minsculas de las maysculas: la variable a no es la variable A.
Se utilizan {} para delimitar bloques de sentencias (if, while, etc.).
Cada lnea termina con ; (punto y coma) excepto if, while, for.
Las condiciones van entre parntesis.
Carreras: Analista de Sistemas y Licenciatura en Sistemas
Asignatura: Resolucin de Problemas y Algoritmos
Docente: Lic. Vernica L. Vanoli
Apunte de Ctedra
- Pgina 118 de 165 -
Veamos como sera el Ejercicio 8.e del Prctico 4, en Java:
{
//declaracin de variables e inicializacin de contadores
int CONTB, CONTA, CONTM, CONTP, CONT;
char ELEMENTO;
CONTB=0;
CONTA=0;
CONTM=0;
CONTP=0;
//carteles e inicio del inventario
System.out.println("Inventario de una escuela");
System.out.println("Datos: B: borradores; A: bancos;
M: mesas; P: pizarrones");
for(CONT=1; CONT<=2500; CONT++)
{
//carga y control de carga
do
ELEMENTO=Console.readChar("Ingrese un elemento: ");
while(ELEMENTO != 'A' & ELEMENTO != 'B' &
ELEMENTO != 'M' & ELEMENTO != 'P');
//verificacin y conteo del elemento cargado
switch(ELEMENTO)
{
case 'B': {
CONTB=CONTB + 1;
break;
}
case 'A': {
CONTA=CONTA + 1;
break;
}
case 'M': {
CONTM=CONTM + 1;
break;
}
case 'P': {
CONTP=CONTP + 1;
break;
}
}
}
//resultados
System.out.println("Resultado del inventario");
System.out.println("La cantidad de borradores (B) es: "+CONTB);
System.out.println("La cantidad de bancos (A) es: "+CONTA);
System.out.println("La cantidad de mesas (M) es: "+CONTM);
System.out.println("La cantidad de pizarrones (P) es: "+CONTP);
}
Carreras: Analista de Sistemas y Licenciatura en Sistemas
Asignatura: Resolucin de Problemas y Algoritmos
Docente: Lic. Vernica L. Vanoli
Apunte de Ctedra
- Pgina 119 de 165 -
Clases en Java
Estructura de una clase:
class NombreClase
{
//declaracin de atributos
tipo_de_dato nombreAtributo;
.
.
.
//declaracin de mtodos
tipo_de_dato nombreDelMetodo(lista de parmetros)
{
//declaracin_de_variables_locales
...
//cuerpo_del_mtodo
...
return [resultado];
}
.
.
.
}
Veamos como sera el Ejercicio 5 del Prctico 8, en Java:
class Hora
{
//atributos de la clase Hora
int hora, minuto, segundo;
//constructor de la clase Hora
Hora(int HH, int MM, int SS)
{
if(validarHora(HH) && validarMinutoSegundo(MM) &&
validarMinutoSegundo(SS))
{
hora=HH;
minuto=MM;
segundo=SS;
}
else
{
hora=0;
minuto=0;
segundo=0;
}
}
Carreras: Analista de Sistemas y Licenciatura en Sistemas
Asignatura: Resolucin de Problemas y Algoritmos
Docente: Lic. Vernica L. Vanoli
Apunte de Ctedra
- Pgina 120 de 165 -
//verifica si es o no vlida la hora
boolean validarHora(int HH)
{
if(HH >= 0 && HH < 24)
return true;
else
return false;
}
//verifica si es o no vlida tanto los minutos como los segundos
boolean validarMinutoSegundo(int MS)
{
if(MS >= 0 && MS < 60)
return true;
else
return false;
}
//permite cambiar el valor de la hora
//void es la palabra reservada a utilizar en los casos
//dnde el mtodo no devuelve nada
void setHora(int HH)
{
if(validarHora(HH))
hora=HH;
return;
}
//devuelve el valor de la hora
int getHora()
{
return hora;
}
//permite cambiar el valor de los minutos
void setMinuto(int MM)
{
if(validarMinutoSegundo(MM))
minuto=MM;
return;
}
//devuelve el valor de los minutos
int getMinuto()
{
return minuto;
}
//permite cambiar el valor de los segundos
void setSegundo(int SS)
{
if(validarMinutoSegundo(SS))
segundo=SS;
return;
}
Carreras: Analista de Sistemas y Licenciatura en Sistemas
Asignatura: Resolucin de Problemas y Algoritmos
Docente: Lic. Vernica L. Vanoli
Apunte de Ctedra
- Pgina 121 de 165 -
//devuelve el valor de los segundos
int getSegundo()
{
return segundo;
}
//devuelve la hora pasada en minutos
int devolverHoraEnMinutos()
{
int MIN;
MIN=minuto + hora * 60;
return MIN;
}
//devuelve la hora pasada en segundos
int devolverHoraEnSegundos()
{
int MIN, SEG;
MIN=devolverHoraEnMinutos();
SEG=segundo + MIN * 60;
return SEG;
}
//modifica la hora aumentndola en la cantidad de minutos ingresados
//si el valor es negativo, lo restara
void cambiarHoraConMinutos(int MM)
{
minuto=minuto + MM;
if(minuto >= 60)
do
{
if(minuto == 60)
minuto=0;
else
minuto=minuto - 60;
hora=hora + 1;
}
while(minuto >= 60);
if(hora > 24)
do
hora=hora - 24;
while(hora > 24);
return;
}
//muestra la hora en el formato hh:mm:ss
void mostrarFormatoHora()
{
System.out.println(hora+":"+minuto+":"+segundo);
return;
}
}
Convenciones:
1. El nombre de la clase va en forma completa y el comienzo de cada palabra en mayscula.
Ejemplo: HoraDigital.
Carreras: Analista de Sistemas y Licenciatura en Sistemas
Asignatura: Resolucin de Problemas y Algoritmos
Docente: Lic. Vernica L. Vanoli
Apunte de Ctedra
- Pgina 122 de 165 -
2. El nombre de los mtodos va en forma completa y el comienzo de cada palabra, menos la
primera, en mayscula. Ejemplo: cambiarHoraConMinutos.
3. El nombre de los atributos va en minscula. Ejemplo: minuto.
Mtodo de acceso a lo atributos
Un atributo implica dos mtodos, uno para actualizar su estado (mtodo comando) y otro para
devolverlo (mtodo consulta). Dado que los datos de un objeto no se pueden acceder directamente, es
necesario contar con mtodos de acceso a los atributos. En el ejemplo anterior podemos ver como se
puede actualizar o modificar el valor de los minutos (set) y como se puede devolver u obtener dicho
valor (get).
void setMinuto(int MM)
{
minuto=MM;
return;
}
int getMinuto()
{
return minuto;
}
Estos dos mtodos aseguran que slo el objeto accede a sus datos. Por otra parte, si tenemos:
int getMinuto()
{
return minuto;
}
void mostrarMinuto()
{
System.out.print(minuto);
return;
}
La diferencia radica en que a travs del primer mtodo el objeto devuelve el valor del atributo minuto
y quien ha enviado el mensaje puede con l realizar todas las operaciones que desee, como hacer
clculos, comparar con otras horas, e inclusive mostrar el valor. Esto ltimo lo realiza el segundo
mtodo, que slo muestra el valor del minuto y no da la posibilidad de manipularlo.
El mtodo main
En una aplicacin en Java existirn, como ya se indic, cientos de objetos interactuando. Estos objetos
podrn corresponder a la misma clase o no. Es decir, la solucin de un problema podra requerir de
objetos de tipo Animal, Auto, Fecha, Hora, etc. estas clases representan una entidad. La aplicacin o
programa en la cual los objetos se crean e interactan, es una clase especial, ya que no se corresponde
con una entidad. Esta clase posee el mtodo main (principal en ingls). El mtodo main tiene el
objetivo de posibilitar la ejecucin de un programa. Toda ejecucin de un programa en Java comienza
por ese mtodo, si no estuviera dara un error. Entonces, en una aplicacin tendremos muchas clases
correspondientes a diferentes entidades, y solo una clase con el mtodo main.
Veamos como sera el principal para probar la clase Hora:
class PruebaHora
{
public static void main(String[] args)
{
int HH, MM, SS, MIN;
System.out.println("** Primer ejemplo **");
Hora HOR1=new Hora(14, 15, 20);
System.out.print("La hora cargada es la siguiente: ");
HOR1.mostrarFormatoHora();
System.out.println("La hora pasada a minutos es: "+
HOR1.devolverHoraEnMinutos()+" minutos");
Carreras: Analista de Sistemas y Licenciatura en Sistemas
Asignatura: Resolucin de Problemas y Algoritmos
Docente: Lic. Vernica L. Vanoli
Apunte de Ctedra
- Pgina 123 de 165 -
System.out.println("La hora pasada a segundos es: "+
HOR1.devolverHoraEnSegundos()+" segundos");
MIN=Console.readInt("Ingrese cantidad de minutos para
aumentar a la hora: ");
HOR1.cambiarHoraConMinutos(MIN);
System.out.print("La hora modificada es: ");
HOR1.mostrarFormatoHora();
System.out.println("** Segundo ejemplo **");
Hora HOR2=new Hora(33, 50, 20);
System.out.print("La hora cargada es la siguiente: ");
HOR2.mostrarFormatoHora();
if(HOR2.getHora() == 0 && HOR2.getMinuto() == 0 &&
HOR2.getSegundo() == 0)
{
HOR2.setHora(23);
HOR2.setMinuto(50);
HOR2.setSegundo(79);
}
System.out.print("La hora modificada es la siguiente: ");
HOR2.mostrarFormatoHora();
System.out.println("La hora pasada a minutos es: "+
HOR2.devolverHoraEnMinutos()+" minutos");
System.out.println("La hora pasada a segundos es: "+
HOR2.devolverHoraEnSegundos()+" segundos");
MIN=Console.readInt("Ingrese cantidad de minutos para
aumentar a la hora: ");
HOR2.cambiarHoraConMinutos(MIN);
System.out.print("La hora modificada es: ");
HOR2.mostrarFormatoHora();
}
}
En este ejemplo, Hora es una clase que representa a una entidad bien definida del mundo real, y de la
cual se podrn crear Objetos. En cambio PruebaHora, no representa ninguna entidad, su nico
propsito es contener el mtodo main, el cual permite la ejecucin de un programa. Probar dicho
ejemplo y entender que realiza cada lnea de cdigo.
Referencias en Java
En un programa un objeto es una variable. Esta variable corresponde a una instancia de alguna clase,
es decir su tipo, al igual que una variable de tipo simple (int, float, etc.). Pero existe una importante
diferencia, las variables utilizadas para identificar objetos, son referencias o punteros.
En el siguiente cdigo:
int contador; // 1
contador=0; // 2
En la lnea 1, se reserva un espacio en memoria identificado con el identificador contador para
almacenar un dato entero. En la lnea 2, en el espacio de memoria identificado como contador se
asigna (almacena) el valor entero 0. Es decir, en el espacio de memoria identificado como contador se
almacena un valor. Este mecanismo para manejar memoria es simple y se conoce como
direccionamiento directo. Para las variables correspondientes a objetos, el mecanismo es diferente y
se conoce como direccionamiento indirecto.
Carreras: Analista de Sistemas y Licenciatura en Sistemas
Asignatura: Resolucin de Problemas y Algoritmos
Docente: Lic. Vernica L. Vanoli
Apunte de Ctedra
- Pgina 124 de 165 -
Supongamos el siguiente cdigo:
Hora objHora; // 1
objHora=new Hora(12, 20, 10); // 2
En la lnea 1, se reserva un espacio en memoria identificado con el identificador objHora para
almacenar una direccin de memoria (puntero). Al momento de la declaracin, se asigna
automticamente un valor nulo. En la lnea 2, cuando se crea el objeto (mediante la sentencia new), se
obtiene de memoria un espacio diferente que contendr todos los datos del objeto objHora. Es decir,
en el espacio de memoria identificado como objHora, no se almacenan los datos del objeto objHora.
En objHora, se almacena una direccin memoria que apunta al espacio en memoria que contiene los
datos de objHora (hora, minuto y segundo).
La sentencia new busca espacio para una instancia de un objeto de una clase determinada e inicializa la
memoria a los valores adecuados. Luego invoca al mtodo constructor de la clase, proporcionndole
los argumentos adecuados. La sentencia new devuelve una referencia a s mismo, que es
inmediatamente asignada a la variable referencia.
Debemos ser cuidadosos en nuestros programas y tener en cuenta que los objetos son variables,
especialmente cuando hacemos asignaciones.
Ilustramos con un el siguiente ejemplo:
Pensemos en una referencia como si se tratase de la llave electrnica de la habitacin de un hotel.
Vamos a utilizar precisamente este ejemplo del hotel para demostrar el uso y la utilizacin que
podemos hacer de las referencias en Java. Primero crearemos la clase Habitacion, implementada en el
archivo Habitacion.java, mediante instancias de la cual construiremos nuestro hotel:
class Habitacion
{
int numHabitacion;
int numCamas;
Habitacion(int numeroHab, int camas)
{
setHabitacion(numeroHab);
setCamas(camas);
}
int getHabitacion()
{
return numHabitacion;
}
void setHabitacion(int numeroHab)
{
numHabitacion=numeroHab;
return;
}
int getCamas()
{
return numCamas;
}
Carreras: Analista de Sistemas y Licenciatura en Sistemas
Asignatura: Resolucin de Problemas y Algoritmos
Docente: Lic. Vernica L. Vanoli
Apunte de Ctedra
- Pgina 125 de 165 -
void setCamas(int camas)
{
numCamas=camas;
return;
}
}
Vamos a construir nuestro hotel creando habitaciones y asignndole a cada una de ellas su llave
electrnica; tal como muestra el cdigo siguiente del archivo Hotel.java:
class Hotel
{
public static void main(String[] args)
{
//paso 1
Habitacion llaveHab1;
Habitacion llaveHab2;
//paso 2
llaveHab1=new Habitacion(222, 1);
llaveHab2=new Habitacion(1144,3);
}
}
El primer paso es la creacin de las llaves, es decir, definir la variable referencia, por defecto nula. En
el segundo paso se crean las habitaciones. Podemos tener mltiples llaves para una misma habitacin:
Habitacion llaveHab3, llaveHab4;
llaveHab3=llaveHab1;
llaveHab4=llaveHab2;
De este modo conseguimos copias de las llaves. Las habitaciones, en s mismas, no se han tocado en
este proceso. As, ya tenemos dos llaves para la habitacin 222 y otras dos para la habitacin 1144.
Una llave puede ser programada para que funcione solamente con una habitacin en cualquier
momento, pero podemos cambiar su cdigo electrnico para que funcione con alguna otra habitacin;
por ejemplo, para cambiar una habitacin anteriormente utilizada por un empedernido fumador por
otra limpia de olores y con vistas al mar. Entonces cambiemos la llave duplicada de la habitacin del
fumador (la 222) por la habitacin con olor a sal marina, 1144:
llaveHab3=llaveHab2;
Ahora tenemos una llave para la habitacin 222 y tres para la habitacin 1144. Mantendremos una
llave para cada habitacin en la conserjera, para poder utilizarla como llave maestra, en el caso de que
alguien pierda su llave propia.
Alguien con la llave de una habitacin puede hacer cambios en ella, y los compaeros que tengan llave
de esa misma habitacin, no tendrn conocimiento de esos cambios hasta que vuelvan a entrar en la
habitacin. Por ejemplo, vamos a quitar una de las camas de la habitacin, entrando en ella con la llave
maestra:
llaveHab2.setCamas(2);
Ahora cuando los inquilinos entren en la habitacin podrn comprobar el cambio realizado:
Carreras: Analista de Sistemas y Licenciatura en Sistemas
Asignatura: Resolucin de Problemas y Algoritmos
Docente: Lic. Vernica L. Vanoli
Apunte de Ctedra
- Pgina 126 de 165 -
System.out.println(llaveHab4.getCamas());
Este ltimo punto es muy importante, ya que ms de una puntero puede referenciar a un mismo objeto.
En consecuencia, las modificaciones al objeto producidas desde una particular referencia, se reflejaran
para todas las referencias.
En conclusin, una asignacin de variables simples es absolutamente diferente a una asignacin de
variables punteros.
Agregacin y Dependencia
La POO intenta promover la reusabilidad de objetos. No slo se trata de crear clases, sino de usar o
adaptar clases ya hechas. Hay tres formas fundamentales de reutilizar clases, mediante:
composicin/agregacin, herencia y uso/dependencia.
Agregacin: consiste en formar objetos a partir de otros. Cuando entre dos objetos de distintas clases
se produce la relacin se compone de o es parte de o tienen un, estamos en presencia de una
relacin de agregacin o composicin. Por ejemplo, un auto tiene un precio, el precio es un dato real,
simple; pero un auto tiene un motor, y un motor tiene a su vez una serie de particularidades y no todos
los autos tienen el mismo motor. Adems, los motores no slo se usan en los autos, tambin en barcos,
aviones, electrodomsticos, etc. Es decir, Motor debera ser una clase. La relacin se puede describir
como: un auto se compone de un motor, o un auto tiene un motor, o un motor es parte de un
auto.
Por ejemplo:
class Auto
{
Cadena marca;
Motor mot;
.
.
.
}
La agregacin implica que en la clase Auto hay al menos un atributo de tipo Motor. En algn mtodo
de la clase Auto el atributo mot debe ser creado, ya que se encuentra solamente declarado como
atributo. Esto significa que desde cualquier mtodo de la clase Auto se pueden enviar mensajes al
objeto mot.
Dependencia: cuando entre dos objetos de distintas clases se produce la relacin usa o depende,
estamos en presencia de una relacin de dependencia. Por ejemplo, un auto tiene 4 ruedas y si es
necesario cambiar una de ellas, la clase Auto deber tener un mtodo cambiarRueda(). Para poder
cambiar una rueda es necesario usar un criquet, que no es un componente del auto, pero se usa para
cambiar una rueda. Es decir, un objeto de la clase Auto, usar un objeto de la clase Criquet, cada vez
que se ejecute el mtodo cambiarRueda(). La relacin se puede describir como: un auto usa un
criquet.
Por ejemplo:
class Auto
{
.
.
.
Carreras: Analista de Sistemas y Licenciatura en Sistemas
Asignatura: Resolucin de Problemas y Algoritmos
Docente: Lic. Vernica L. Vanoli
Apunte de Ctedra
- Pgina 127 de 165 -
void cambiarRueda(Criquet c)
{
//cdigo
}
void cambiarRueda( )
{
Criquet c=new Criquet();
//cdigo
}
.
.
.
}
La dependencia significa que la clase Auto tiene la posibilidad de enviar mensajes a un objeto de la
clase Criquet, que recibe por parmetro o crea como variable local.
Parmetros
Los parmetros son el mecanismo por el cual se transmiten datos a los mtodos. Existen dos tipos de
parmetros: por valor o copia y por referencia. En Java cuando un parmetro corresponde a un tipo
simple (int, char, float, double, etc.) es siempre por valor, y cuando el parmetro es un objeto es
siempre por referencia.
Un parmetro por valor significa que el mtodo trabaja con una copia del valor original pero no con
el valor en cuestin. En consecuencia, si en el mtodo el valor del parmetro sufriera modificaciones,
stas no se veran reflejadas en el valor original al finalizar el mtodo, puesto que se trabaj con una
copia.
Por ejemplo:
void ejemplo(int num)
{
num=num * 5; //num es una copia del parmetro actual
return;
}
En otra clase se enva un mensaje:
int numero=23;
objeto.ejemplo(numero) //enva una copia de 23
System.out.println(numero) //imprime 23
Al contrario, los parmetros por referencia trabajan con el objeto real enviado. Por lo tanto, todas las
modificaciones que el objeto sufra en el mtodo se reflejaran en el mismo, aun despus de la ejecucin
del mtodo.
Por ejemplo:
void ejemplo(Persona p)
{
p.setEdad(5); //p es una referencia al objeto real
return;
}
Carreras: Analista de Sistemas y Licenciatura en Sistemas
Asignatura: Resolucin de Problemas y Algoritmos
Docente: Lic. Vernica L. Vanoli
Apunte de Ctedra
- Pgina 128 de 165 -
En otra clase si se hace:
Persona per=new Persona();
per.setEdad(44);
System.out.println(per.getEdad()) //imprime 44
objeto.ejemplo(per);
System.out.println(per.getEdad()) //imprime 5
Paquetes
Las clases compiladas (.class) se organizan en paquetes. Un paquete contiene un conjunto de clases. A
su vez, un paquete puede contener a otros paquetes. La estructura es similar a la de los directorios
(carpetas) y archivos en el Explorador de Windows. Los archivos cumplen el papel de las clases Java y
los directorios cumplen el papel de paquetes. De hecho, la estructura de directorios en la que se
organizan los archivos .class (estructura fsica del sistema operativo) debe corresponderse con la
estructura de paquetes definida en los archivos fuente .java.
La palabra clave package permite agrupar clases. Los nombres de los paquetes son palabras separadas
por puntos y se almacenan en directorios que coinciden con esos nombres.
Por ejemplo, si al comienzo de un archivo .java llamado Persona.java se escribe:
package misclases.negocios;
estamos declarando que la clase Persona (el archivo Persona.class) deber residir en una estructura de
directorios misclases\negocios.
El lenguaje Java proporciona una serie de paquetes que incluyen ventanas, utilidades, un sistema de
entrada/salida general, herramientas y comunicaciones. Algunos de los paquetes que se incluyen son:
java.applet, java.awt, java.io, java.lang, java.net, java.util, etc.
Para poder cargar una clase de un paquete determinado se utiliza la palabra clave import,
especificando el nombre del paquete como ruta y nombre de clase.
Por ejemplo,
import java.util.Date; //se importa la clase Date del paquete java.util
import java.awt.*; //se importan todas las clases que contenga el paquete java.awt
El nico paquete que no es necesario importar, ya que Java lo toma por defecto, es java.lang.
Modificadores de acceso
Uno de los beneficios de las clases es que pueden proteger sus atributos y mtodos frente al acceso de
otros objetos. Por qu es esto importante?. Ciertas informaciones y peticiones contenidas en la clase,
las soportadas por los mtodos y atributos accesibles pblicamente en su objeto son correctas para el
consumo de cualquier otro objeto del sistema. Otras peticiones contenidas en la clase son slo para el
uso personal de la clase. Estas otras soportadas por la operacin de la clase no deberan ser utilizadas
por objetos de otros tipos. Se querra proteger esos atributos y mtodos personales a nivel del lenguaje
y prohibir el acceso desde objetos de otros tipos.
En Java se puede utilizar los especificadores de acceso para proteger tanto los atributos como los
mtodos de la clase cuando se declaran. El lenguaje Java soporta cuatro niveles de acceso para los
atributos y mtodos: public, private, protected y todava no especificado, acceso de paquete.
Acceso pblico: es el especificador de acceso ms sencillo. Todas las clases, en todos los paquetes
tienen acceso a los miembros pblicos de la clase. Los miembros pblicos se declaran slo si su
acceso no produce resultados indeseados si un extrao los utiliza. Para declarar un miembro pblico se
utiliza la palabra clave public. Por ejemplo,
Carreras: Analista de Sistemas y Licenciatura en Sistemas
Asignatura: Resolucin de Problemas y Algoritmos
Docente: Lic. Vernica L. Vanoli
Apunte de Ctedra
- Pgina 129 de 165 -
package Griego;
public class Alpha
{
public int soyPublico;
public void metodoPublico()
{
System.out.println(metodoPublico);
return;
}
}
import Griego.*;
package Romano;
class Beta
{
void metodoAccesor()
{
Alpha a = new Alpha();
a.soyPublico = 10; // LEGAL
a.metodoPublico(); // LEGAL
return;
}
}
Como se puede ver en el ejemplo anterior, Beta puede crear objetos de la clase Alpha, inspeccionar y
modificar legalmente el atributo soyPublico de la clase Alpha y puede llamar legalmente al mtodo
metodoPublico(). Si no se coloca ningn modificador de acceso, Java asume por defecto que el
miembro es pblico.
Acceso privado: Es el nivel de acceso ms restringido. Un miembro privado es accesible slo para la
clase en la que est definido. Se utiliza este acceso para declarar miembros que slo deben ser
utilizados por la clase. Esto incluye los atributos que contienen informacin que si se accede a ella
desde el exterior podra colocar al objeto en un estado de inconsistencia, o los mtodos que llamados
desde el exterior pueden ponen en peligro el estado del objeto o del programa donde se est
ejecutando. Los miembros privados son como secretos. Para declarar un miembro privado se utiliza la
palabra clave private en su declaracin. La clase siguiente contiene un atributo y un mtodo privados:
class Alpha
{
private int soyPrivado;
private void metodoPrivado()
{
System.out.println(metodoPrivado);
return;
}
}
Los objetos del tipo Alpha pueden inspeccionar y modificar el atributo soyPrivado y pueden invocar el
mtodo metodoPrivado(), pero los objetos de otros tipos no pueden acceder. Por ejemplo, la clase Beta
definida aqu:
Carreras: Analista de Sistemas y Licenciatura en Sistemas
Asignatura: Resolucin de Problemas y Algoritmos
Docente: Lic. Vernica L. Vanoli
Apunte de Ctedra
- Pgina 130 de 165 -
class Beta
{
void metodoAccesor()
{
Alpha a = new Alpha();
a.soyPrivado = 10; // ILEGAL
a.metodoPrivado(); // ILEGAL
return;
}
}
La clase Beta no puede acceder al atributo soyPrivado ni al mtodo metodoPrivado() de un objeto del
tipo Alpha porque Beta no es del tipo Alpha. Si una clase est intentando acceder a una variable
miembro a la que no tiene acceso, el compilador mostrar el siguiente mensaje de error y no compilar
su programa:
Beta.java:6: soyPrivado has private access in Alpha
a.soyPrivado = 10; // ILEGAL
^
Y si un programa intenta acceder a un mtodo al que no tiene acceso, generar el siguiente mensaje de
error de compilacin:
Beta.java:7: metodoPrivado() has private access in Alpha
a.metodoPrivado(); // ILEGAL
^
Acceso de Paquete: El ltimo nivel de acceso es el que se obtiene si no se especifica ningn otro
nivel de acceso a los miembros. Este nivel de acceso permite que las clases del mismo paquete que la
clase tengan acceso a los miembros. Este nivel de acceso asume que las clases del mismo paquete son
amigas de confianza. Este nivel de confianza es como la que extiende a sus mejores amigos y que
incluso no la tiene con su familia. Por ejemplo, esta versin de la clase Alpha declara un atributo y un
mtodo con acceso de paquete. Alpha reside en el paquete Griego:
package Griego;
class Alpha
{
int estoyEmpaquetado;
void metodoEmpaquetado()
{
System.out.println(metodoEmpaquetado);
return;
}
}
package Griego;
class Beta
{
void metodoAccesor()
{
Carreras: Analista de Sistemas y Licenciatura en Sistemas
Asignatura: Resolucin de Problemas y Algoritmos
Docente: Lic. Vernica L. Vanoli
Apunte de Ctedra
- Pgina 131 de 165 -
Alpha a = new Alpha();
a.estoyEmpaquetado = 10; // LEGAL
a.metodoEmpaquetado(); // LEGAL
return;
}
}
Entonces, Beta puede acceder legalmente a estoyEmpaquetado y metodoEmpaquetado() de la clase
Alpha dado que ambas clases se encuentran en el mismo paquete.
Sobrecarga
Se produce cuando existen en la misma clase dos o ms mtodos (incluido el constructor) con el
mismo identificador (nombre) pero con diferentes listas de parmetros (en nmero y/o en tipo). Cada
mtodo realiza una operacin en funcin de los argumentos que recibe. Semnticamente la sobrecarga
resuelve el problema de que una determinada funcin se puede realizar de diferentes formas
(algoritmos) con distintos datos (parmetros). La sobrecarga se resuelve en tiempo de compilacin,
dado que los mtodos se deben diferenciar en el tipo o en el nmero de parmetros.
Por ejemplo:
class VectorEnteros
{
int[] elementos;
int dimension, actual;
VectorEnteros(int DIM)
{
if(DIM > 0)
dimension=DIM;
else
dimension=10;
actual=0;
elementos=new int[dimension];
}
VectorEnteros( )
{
dimension=10;
actual=0;
elementos=new int[dimension];
}
.
.
.
}
El mtodo constructor de la clase VectorEnteros esta sobrecargado, es decir un vector de enteros se
puede construir de 2 maneras diferentes. La diferencia se encuentra en los parmetros, en uno se
permite determinar la dimensin del vector y en otro no. Se podra agregar un constructor ms que
adems de la dimensin reciba por parmetro un valor entero cuyos dgitos sern cargados al vector,
esto permitira que el vector no se cargue vaco, por ejemplo.
Carreras: Analista de Sistemas y Licenciatura en Sistemas
Asignatura: Resolucin de Problemas y Algoritmos
Docente: Lic. Vernica L. Vanoli
Apunte de Ctedra
- Pgina 132 de 165 -
Operador THIS
El operador this se utiliza para hacer referencia a los miembros de la propia clase. Uno de los usos ms
comunes es cuando existen otros elementos (identificadores) en la clase, con el mismo nombre para
distinguir.
Por ejemplo,
public class MiClase
{
private int i;
public MiClase(int i)
{
this.i = i; //al atributo i de la clase se le asigna el parmetro i
}
}
Nota: recuerde que el uso de identificadores iguales puede ocasionar inestabilidad en la clase, si no se
utilizan correctamente.
Arreglos en Java
Dado que los arreglos (arrays) son tipos de datos muy utilizados en programacin, en Java son objetos
predefinidos. Se pueden declarar y crear arrays de cualquier tipo:
char[] palabra=new char[10];
int[] numeros=new int[100];
Los corchetes se pueden colocar de dos formas en la declaracin:
tipo[] identificador; //indica que todos los identificadores son arrays del tipo
tipo identificador[]; //es array slo el identificador al que le siguen los [ ].
Veamos en estos ejemplos como se escriben distintas declaraciones de arrays.
char cad[], p; //cad es un array de tipo char; p es una variable de tipo char.
int[] v, w; //tanto v como w son declarados arrays unidimensionales de tipo int.
double[] m, t[], x; //m y x son array de tipo double; t es un array de array de tipo double.
Tambin, se pueden construir arrays de arrays (matrices):
int tabla[][]=new int[4][5];
Los lmites de los arrays se comprueban en tiempo de ejecucin para evitar desbordamientos y la
corrupcin de memoria.
En Java un array es realmente un objeto, porque tiene redefinido el operador [ ]. Tiene un mtodo
miembro length, que se puede utilizar cmo mtodo para conocer la longitud de cualquier array.
Algunos ejemplos ms completos:
//de vector
char vector[]=new char[100];
System.out.println(La longitud del vector es: +vector.length); //La longitud del vector es: 100
//de matriz
int matriz[][]=new int[10][3];
//La cantidad de filas de la matriz es: 10
Carreras: Analista de Sistemas y Licenciatura en Sistemas
Asignatura: Resolucin de Problemas y Algoritmos
Docente: Lic. Vernica L. Vanoli
Apunte de Ctedra
- Pgina 133 de 165 -
System.out.println(La cantidad de filas de la matriz es: +matriz.length);
//La cantidad de columnas de la matriz es: 3
System.out.println(La cantidad de columnas de la matriz es: +matriz[0].length);
Para crear un array hay dos mtodos bsicos:
1. Crear un array vaco: int lista[]=new int[50];
2. Crear un array con sus valores iniciales: int lista[]={5, 4, 3, 2};
Esto que es equivalente a:
int lista[]=new int[4];
lista[0]=5;
lista[1]=4;
lista[2]=3;
lista[3]=2;
En Java, al ser un tipo de datos verdadero, se dispone de comprobaciones exhaustivas del correcto
manejo del array; por ejemplo, de la comprobacin de sobrepasar los lmites definidos para el array,
para evitar desbordamientos o corrupcin de memoria.
Al igual que los dems objetos en Java, la declaracin del array no localiza, o reserva, memoria para
contener los datos. En su lugar, simplemente localiza memoria para almacenar una referencia al array.
La memoria necesaria para almacenar los datos que componen el array se buscar en memoria
dinmica a la hora de instanciar y crear realmente el array.
Los ndices de un array siempre empiezan en 0. Adems, en Java no se puede rellenar un array sin
declarar el tamao con el operador new. Como se ilustra en la ltima parte del siguiente cdigo. Este
ejemplo intenta ilustrar un aspecto interesante del uso de arrays en Java. Se trata de que Java puede
crear arrays multidimensionales, que se veran como arrays de arrays. Aunque esta es una
caracterstica comn a muchos lenguajes de programacin, en Java, sin embargo, los arrays
secundarios no necesitan ser todos del mismo tamao. En el ejemplo, se declara e instancia un array de
enteros, de dos dimensiones, con un tamao inicial (tamao de la primera dimensin) de 3. Los
tamaos de las dimensiones secundarias (tamao de cada uno de los subarrays) son 2, 3 y 4,
respectivamente.
Veamos un ejemplo para ilustrar la creacin y manipulacin de un array de dos dimensiones en donde
los subarrays tienen diferente tamao.
class EjemploMatriz
{
public static void main(String[] args)
{
//Declaramos un array de dos dimensiones con un tamao de 3 en
//la primera dimensin y diferentes tamaos en la segunda
int miArray[][]=new int[3][]; //No especificamos el tamao
//de las columnas
miArray[0]=new int[2]; //El tamao de la segunda dimensin es 2
miArray[1]=new int[3]; //El tamao de la segunda dimensin es 3
miArray[2]=new int[4]; //El tamao de la segunda dimensin es 4
//Rellenamos el array con datos
for(int i=0; i < 3; i++)
for(int j=0; j < miArray[i].length; j++)
miArray[i][j]=i * j;
Carreras: Analista de Sistemas y Licenciatura en Sistemas
Asignatura: Resolucin de Problemas y Algoritmos
Docente: Lic. Vernica L. Vanoli
Apunte de Ctedra
- Pgina 134 de 165 -
//Visualizamos los datos que contiene el array
for(int i=0; i < 3; i++)
{
for(int j=0; j < miArray[i].length; j++)
System.out.print(miArray[i][j]);
System.out.println();
}
//Hacemos un intento de acceder a un elemento que se encuentre
//fuera de los lmites del array
System.out.println("Acceso a un elemento fuera de limites");
miArray[4][0]=7; //Esa sentencia originar el lanzamiento
//de una excepcin de tipo
//ArrayIndexOutOfBounds
}
}
En este ejemplo, tambin se pueden observar alguna otra cosa, como es el hecho de que cuando se
declara un array de dos dimensiones, no es necesario indicar el tamao de la dimensin secundaria a la
hora de la declaracin del array, sino que puede declararse posteriormente el tamao de cada uno de
los subarrays. Tambin se puede observar el resultado de acceder a elementos que se encuentran fuera
de los lmites del array; Java protege la aplicacin contra este tipo de errores de programacin.
En Java, si se intenta hacer esto, el Sistema generar una excepcin, tal como se muestra en el
ejemplo. En l, la excepcin simplemente hace que el programa termine, pero se podra recoger esa
excepcin e implementar un controlador de excepciones (exception handler) para corregir
automticamente el error, sin necesidad de abortar la ejecucin del programa.
La salida por pantalla de la ejecucin del ejemplo sera:
00
012
0246
Acceso a un elemento fuera de lmites
Exception in thread "main" java.lang.ArrayIndexOutOfBoundsException: 4
at EjemploMatriz.main(EjemploMatriz.java:25)
En el siguiente cdigo se ilustra otro aspecto del uso de arrays en Java. Se trata, en este caso, de que
Java permite la asignacin de un array a otro. Sin embargo, hay que extremar las precauciones cuando
se hace esto, porque lo que en realidad est pasando es que se est haciendo una copia de la referencia
a los mismos datos en memoria. Y, tener dos referencias a los mismos datos no parece ser una buena
idea, porque los resultados pueden despistar.
int[] primerArray=new int[3];
int[] segundoArray;
for(int i=0; i < 3; i++)
primerArray[i]=i;
segundoArray=new int[3];
segundoArray=primerArray;
En un array se pueden almacenar elementos de tipos bsicos (int, char, double, etc.) y objetos. En este
ltimo caso, el arreglo debe verse como un arreglo de punteros.
Animal[] vectAnimal=new Animal[12];
Animal objAnimal;
Carreras: Analista de Sistemas y Licenciatura en Sistemas
Asignatura: Resolucin de Problemas y Algoritmos
Docente: Lic. Vernica L. Vanoli
Apunte de Ctedra
- Pgina 135 de 165 -
for(int i=0; i <12; i++)
{
objAnimal=new Animal();
vectAnimal[i]=objAnimal;
}
La clase Vector y Matriz
Dado que los arreglos son objetos, lo ms conveniente es codificar una clase que permita un uso
simple de los arreglos (vectores y matrices) y totalmente transparente para los programas que lo
utilicen, adems de facilitar la reutilizacin de los mismos. Las clases vistas en unidades anteriores
sobre Arreglos, pueden ser pasadas al Lenguaje Java, para su correcta utilizacin. Podemos realizar
nuestra clase personalizada de acuerdo al tipo de arreglo que implementemos, pero tambin podemos
hacer uso de la clase Vector que proporciona Java en su paquete java.util.
Programas en Java
Un programa codificado en el Lenguaje Java debe grabarse en un archivo de texto, cuyo nombre debe
coincidir totalmente con el nombre de la clase y la extensin debe ser .java. Es decir, el archivo fuente
sera por ejemplo: Hora.java, PruebaHora.java, Habitacion.java, Hotel.java. Luego de compilar el
archivo fuente se obtiene un archivo ejecutable con el mismo nombre pero con extensin .class.
JDK proporciona en su carpeta \bin, las aplicaciones respectivas para compilar y ejecutar un archivo
con Java.
Para compilar
javac Hora.java
javac PruebaHora.java
Para ejecutar
java PruebaHora
Estos comandos deberan utilizarse bajo el Smbolo del Sistema c:\. Hay que tener en cuenta que para
poder realizar estas tareas se necesita aadir la carpeta a la variable de entorno PATH.
Java facilita la creacin de entornos de desarrollo integrados (IDE) de modo flexible, poderoso y
efectivo. Los programadores ahora disponen de herramientas y aplicaciones de programacin gratuitas
(Eclipse, NetBeans, JCreator LE, DrJava, BlueJ, FreeJava, entre otras), open-source (Eclipse,
NetBeans, entre otras), entornos comerciales como las corporaciones Borland (JBuilder), Oracle
(JDeveloper), Symantec (Visual Caf), Microsoft (Visual J++ o Visual Java), IBM (Visual Age),
JetBrains (IntelliJ IDEA), Allaire de Adobe (Kawa), entre otros. Algunas herramientas son ms
sofisticadas que otras, dado que proporcionan manejos ms complejos como lo son los entornos
visuales, la documentacin, los debuggers y los visualizadores de jerarqua de clases. Esto proporciona
una gran progresin a los entornos de desarrollo Java.
API
Una API (del ingls Application Programming Interface - Interfaz de Programacin de Aplicaciones)
es un conjunto de especificaciones de comunicacin entre componentes software. Representa un
mtodo para conseguir abstraccin en la programacin, generalmente (aunque no necesariamente)
entre los niveles o capas inferiores y los superiores del software. Uno de los principales propsitos de
una API consiste en proporcionar un conjunto de funciones de uso general, por ejemplo, para dibujar
ventanas o iconos en la pantalla. De esta forma, los programadores se benefician de las ventajas de la
API haciendo uso de su funcionalidad, evitndose el trabajo de programar todo desde el principio. Las
APIs asimismo son abstractas: el software que proporciona una cierta API generalmente es llamado la
implementacin de esa API.
Carreras: Analista de Sistemas y Licenciatura en Sistemas
Asignatura: Resolucin de Problemas y Algoritmos
Docente: Lic. Vernica L. Vanoli
Apunte de Ctedra
- Pgina 136 de 165 -
Una herramienta muy til son las pginas HTML con la documentacin del API de Java. A
continuacin veremos alguna de las clases que forman parte del conjunto de clases del Lenguaje Java.
La clase String (Cadenas)
Una secuencia de datos del tipo caracter se conoce como string (cadena) y en el entorno Java est
implementada por la clase String (un miembro del paquete java.lang).
Formato general:
String nombre_variable;
Por ejemplo:
String cadena;
String nombre;
String palabra=Programar;
El segundo uso de String es el uso de cadenas literales (una cadena de caracteres entre comillas ):
Hola mundo!. El compilador asigna implcitamente espacio para un objeto String cuando encuentra
una cadena literal.
Los objetos String son inmutables, es decir, no se pueden modificar una vez que han sido creados. El
paquete java.lang proporciona una clase diferente, StringBuffer, que se podr utilizar para crear y
manipular caracteres al vuelo.
Concatenacin de Cadenas
Java permite concatenar cadenas fcilmente utilizando el operador +. Como lo hemos visto al utilizar
el mtodo System.out.println(). El siguiente fragmento de cdigo concatena tres cadenas para producir
su salida.
int contador=3;
String salida=La entrada tiene +contador+ cadenas.;
System.out.println(salida);
Dos de las cadenas concatenadas son cadenas literales: La entrada tiene y cadenas.. La tercera
cadena (la del medio) es un entero que primero se convierte a cadena y luego se concatena con las
otras. Java posee gran capacidad para el manejo de cadenas dentro de sus clases String y StringBuffer.
Un objeto String representa una cadena alfanumrica de un valor constante que no puede ser cambiada
despus de haber sido creada. Un objeto StringBuffer representa una cadena cuyo tamao puede
variar, o puede ser modificada por programa.
Los Strings son objetos constantes y, por lo tanto, muy baratos para el sistema. La mayora de los
mtodos relacionados con cadenas esperan valores String como argumentos y devuelven valores
String.
Existen varios constructores (sobrecargados) para crear nuevas cadenas, entre ellos:
String();
String(String original);
String(char[] valor);
String(char[] valor, int inicio, int cantidad);
String(byte[] bytes);
String(byte bytes[], int inicio, int longitud);
String(StringBuffer buffer);
Carreras: Analista de Sistemas y Licenciatura en Sistemas
Asignatura: Resolucin de Problemas y Algoritmos
Docente: Lic. Vernica L. Vanoli
Apunte de Ctedra
- Pgina 137 de 165 -
Por ejemplo:
String materia=new String(Resolucin de Problemas y Algoritmos);
char[] palabra={C, L, A, S, E};
String cadena=new String(palabra); //crea la cadena a partir de un vector de caracteres
Una reflexin especial merecen los arrays de Strings. La siguiente sentencia declara e instancia un
array de referencias a cinco objetos de tipo String:
String[] miArray=new String[5];
este array no contiene los datos de las cadenas. Solamente reserva una zona de memoria para
almacenar las cinco referencias a cadenas. No se guarda memoria para almacenar los caracteres que
van a componer esas cinco cadenas, por lo que hay que reservar expresamente esa memoria a la hora
de almacenar los datos concretos de las cadenas, tal como se hace en la siguiente lnea de cdigo:
miArray[0]=new String( Esta es la primera cadena);
miArray[1]=new String( Esta es la segunda cadena);
miArray[2]=new String( Esta es la tercera cadena);
miArray[3]=new String( Esta es la cuarta cadena);
miArray[4]=new String( Esta es la quinta cadena);
Mtodos bsicos
int length(); Devuelve la longitud de la cadena.
char charAt(int indice); Devuelve el caracter que se encuentra en la
posicin que indica el ndice.
Mtodos de Comparacin de Strings
boolean equals(Object unObjeto); Compara la cadena con el objeto especificado.
boolean equalsIgnoreCase(String otraCadena); Compara la cadena con otraCadena, ignorando
las maysculas o minsculas.
int compareTo(String otraCadena); Compara dos cadenas lexicogrficamente. Es
decir, retorna un entero menor que cero si la
cadena es lxicamente menor que otraCadena.
Devuelve cero si las dos cadenas son lxicamente
iguales y un entero mayor que cero si la cadena
es lxicamente mayor que otraCadena.
Mtodos de Comparacin de Subcadenas
Prueba si dos regiones de la cadena son iguales.
boolean regionMatches(int inicioCadena, String otraCadena, int inicioOtraCadena, int long);
boolean regionMatches(boolean mayMin, int inicioCadena, String otraCadena, int
inicioOtraCadena, int long);
Determina si la cadena comienza o termina con un cierto prefijo o sufijo comenzando en un
determinado desplazamiento.
boolean startsWith(String prefijo);
boolean startsWith(String prefijo, int inicio);
boolean endsWith(String sufijo);
Carreras: Analista de Sistemas y Licenciatura en Sistemas
Asignatura: Resolucin de Problemas y Algoritmos
Docente: Lic. Vernica L. Vanoli
Apunte de Ctedra
- Pgina 138 de 165 -
Devuelve el primer/ltimo ndice de un caracter/cadena empezando la bsqueda a partir de un
determinado desplazamiento.
int indexOf(int caracter);
int indexOf(int caracter, int inicio);
int lastIndexOf(int caracter);
int lastIndexOf(int caracter, int inicio);
int indexOf(String cadena);
int indexOf(String cadena, int inicio);
int lastIndexOf(String cadena);
int lastIndexOf(String cadena, int inicio);
Modificaciones sobre la cadena, obteniendo subcadenas, concatenando cadenas, reemplazando
caracteres, conversiones a minsculas/maysculas y ajustando los espacios en blanco tanto al
comienzo y como al final de la cadena.
String substring(int inicio);
String substring(int inicio, int fin);
String concat(String cadena);
String replace(char caracterViejo, char caracterNuevo);
String toLowerCase();
String toUpperCase();
String trim();
Mtodos de Conversin para otros tipos de datos.
void getChars(int inicio, int fin, char destino[], int inicioDestino);
void getBytes(int inicio, int fin, byte destino[], int inicioDestino);
String toString();
char toCharArray();
int hashCode();
La clase String posee numerosos mtodos para transformar valores de otros tipos de datos a su
representacin como cadena. Todos estos mtodos tienen el nombre de valueOf, estando el mtodo
sobrecargado para todos los tipos de datos bsicos.
Clases estticas (STATIC)
Se llama as coloquialmente a las clases que tienen todos sus atributos y mtodos estticos y que no
permiten ser instanciadas. Ese tipo de clases suelen ser repositorios de atributos y/o mtodos y suelen
alejarse un poco de la idea de programacin orientada a objetos.
Atributos Static
La declaracin de un atributo de clase se hace usando static. El significado de un atributo static es que
todas las instancias de la clase (todos los objetos instanciados de la clase) contienen la mismas
variables de clase o estticas.
En otras palabras, en un momento determinado se puede querer crear una clase en la que el valor de un
atributo sea el mismo (y de hecho sea el misma atributo) para todos los objetos instanciados a partir
de esa clase. Es decir, que exista una nica copia del atributo, entonces es cuando debe usarse la
palabra clave static.
Carreras: Analista de Sistemas y Licenciatura en Sistemas
Asignatura: Resolucin de Problemas y Algoritmos
Docente: Lic. Vernica L. Vanoli
Apunte de Ctedra
- Pgina 139 de 165 -
class Documento
{
static int version=10;
static String extension=txt;
.
.
.
}
El valor de los atributos version y extension ser el mismo para cualquier objeto instanciado de la
clase Documento. Siempre que un objeto instanciado de Documento cambie el atributo version o
extension, ste cambiar para todos los objetos. Si se examinara en este caso la zona de memoria
reservada por el sistema para cada objeto, se encontrara con que todos los objetos comparten la misma
zona de memoria para cada una de los atributos estticos, por ello, se llaman tambin atributos de
clase, porque son comunes a la clase, a todos los objetos instanciados de la clase.
En Java se puede acceder a los atributos de clase utilizando el nombre de la clase y el nombre de la
variable, no es necesario instanciar ningn objeto de la clase para acceder a las variables de clase. En
Java, se accede a los atributos de clase utilizando el nombre de la clase, el operador punto (.) y el
nombre de la variable. La siguiente lnea de cdigo, ya archivista, se utiliza para acceder a la variable
out de la clase System. En el proceso, se accede al mtodo println() del atributo de clase que presenta
una cadena en el dispositivo estndar de salida:
System.out.println(Hola mundo!);
Es importante recordar que todos los objetos de la clase comparten el mismo atributo de clase, porque
si alguno de ellos modifica alguno de esos atributos de clase, quedarn modificados para todos los
objetos de la clase. Esto puede utilizarse como una forma de comunicacin entre objetos.
Mtodos Estticos
Cuando un mtodo de una clase Java se utiliza la palabra static, se obtiene un mtodo esttico o
mtodo de clase.
Lo ms significativo de los mtodos de clase es que pueden ser invocados sin necesidad de que haya
que instanciar ningn objeto de la clase. En Java, se puede invocar un mtodo de clase utilizando el
nombre de la clase, el operador punto y el nombre del mtodo:
MiClase.miMetodoDeClase();
En Java, los mtodos de clase operan solamente como los atributos de clase; no tienen acceso a
variables de instancia de la clase, a no ser que se cree un nuevo objeto y se acceda a los atributos de
instancia a travs de ese objeto.
Si se observa el siguiente trozo de cdigo de ejemplo:
class Documento
{
static int version=10;
int capitulos;
static void agregarCapitulo()
{
capitulos++; //ESTO NO FUNCIONA
return;
Carreras: Analista de Sistemas y Licenciatura en Sistemas
Asignatura: Resolucin de Problemas y Algoritmos
Docente: Lic. Vernica L. Vanoli
Apunte de Ctedra
- Pgina 140 de 165 -
}
static void modificarVersion(int i)
{
version++; //ESTO SI FUNCIONA
return;
}
}
La modificacin del atributo capitulos no funciona porque se est violando una de las reglas de acceso
al intentar acceder desde un mtodo esttico a un atributo no esttico.
Java proporciona clases como: Math, Character, Integer, Float, Double, etc. que disponen de atributos
y mtodos estticos.
La clase Math
Esta clase pertenece al paquete java.lang. La clase Math representa la librera matemtica de Java. Es
una clase esttica, por lo tanto, tiene un constructor privado, lo que significa que no podemos hacer
instancias de ella. Pero como todos sus miembros son estticos, s que podemos acceder a ellos. Para
hacerlo simplemente ponemos el nombre de la clase (en este caso Math), un punto y el nombre de su
atributo/mtodo. Math contiene:
Atributos estticos Descripcin
double Math.PI Devuelve el nmero PI (3.1415...).
double Math.E Devuelve la base del logaritmo natural.
Mtodos estticos Descripcin
int Math.abs(int)
long Math.abs(long)
float Math.abs(float)
double Math.abs(double)
Calcula el valor absoluto de su parmetro (le
cambia el signo si es negativo).
double Math.sin(double)
double Math.cos(double)
double Math.tan(double)
Calcula el seno, coseno o tangente del ngulo
(expresado en radianes) que recibe como
argumento.
double Math.asin(double)
double Math.acos(double)
double Math.atan(double)
Devuelve el ngulo (expresado en radianes)
correspondiente al seno, coseno o tangente
que reciben.
double Math.exp(double) Devuelve el elevado al parmetro.
double Math.sqrt(double) Devuelve la raz cuadrada del parmetro.
double Math.ceil(double)
Redondea al entero menor de los que son
mayores que el parmetro (redondeo hacia
arriba).
double Math.floor(double)
Redondea al entero mayor de los que son
menores que el parmetro (redondeo hacia
abajo).
double Math.pow(double a, double b) a elevado a b.
int Math.rint(double)
long Math.round(double)
int Math.round(float)
Redondea al entero ms cercano.
Carreras: Analista de Sistemas y Licenciatura en Sistemas
Asignatura: Resolucin de Problemas y Algoritmos
Docente: Lic. Vernica L. Vanoli
Apunte de Ctedra
- Pgina 141 de 165 -
int Math.max(int, int)
long Math.max(long, long)
float Math.max(float, float)
double Math.max(double, double)
Devuelve el mximo de los dos valores que
recibe.
int Math.min(int, int)
long Math.min(long, long)
float Math.min(float, float)
double Math.min(double, double)
Devuelve el mnimo de los dos valores que
recibe.
Veamos un ejemplo de la clase Math:
class UsoClaseMath
{
public static void main(String[] args)
{
double num1, num2;
float max;
num1=Console.readDouble("Ingrese un numero real: ");
System.out.println("El primer valor ingresado es: "+num1);
System.out.println("El valor absoluto de "+num1+" es: "+
Math.abs(num1));
System.out.println("El cubo de "+num1+" es: "+Math.pow(num1, 3));
num2=Console.readDouble("Ingrese otro numero real: ");
System.out.println("El segundo valor ingresado es: "+num2);
System.out.println("El redondeo de "+num2+" es: "+Math.round(num2));
System.out.println("El mximo valor de los dos es: "+
Math.max(num1, num2));
}
}
La clase Character
Esta clase pertenece al paquete java.lang. Los mtodos necesarios al trabajar con caracteres estn
contenidos en la clase Character. Esta clase no es esttica, por lo tanto, se puede instanciar, aunque la
mayora de los mtodos son estticos.
Mtodos estticos Descripcin
char Character.isLowerCase(char c)
char Character.isUpperCase(char c)
Devuelven el caracter c convertido a
minsculas o maysculas, respectivamente
boolean Character.isDigit(char c)
boolean Character.isLetter(char c)
boolean Character.isSpace(char c)
Nos devuelven verdadero si el caracter c es
un dgito, una letra o un espacio.
int Character.digit(char c, int base)
Devuelve el nmero correspondiente al
caracter c que recibe como primer
parmetro suponiendo que est expresado
en la base que recibe como segundo
argumento.
char Character.forDigit(int x, int base)
Parecido al anterior, convierte a caracter el
int x que recibe como primer parmetro
suponiendo que est expresado en la base
que recibe como segundo argumento.
Carreras: Analista de Sistemas y Licenciatura en Sistemas
Asignatura: Resolucin de Problemas y Algoritmos
Docente: Lic. Vernica L. Vanoli
Apunte de Ctedra
- Pgina 142 de 165 -
Suponiendo que tenemos un variable carac con la cual crearemos una instancia de la clase Character:
carac=new Character(J);
disponemos de los siguientes mtodos para carac:
Mtodos Descripcin
char carac.charValue( )
Devuelve el caracter que almacena carac,
en este caso J.
String carac.toString( )
Convierte el caracter que hay en carac en
cadena.
int carac.compareTo(Character c)
Compara dos caracteres numricamente, el
caracter carac con c.
Veamos un ejemplo de la clase Character:
class UsoClaseCharacter
{
public static void main(String[] args)
{
char caracter;
int cantDig=0;
int cantLet=0;
System.out.println ("Serie de caracteres (finalizar con punto)");
caracter=Console.readChar("Ingrese un caracter: ");
while(caracter != '.')
{
if(Character.isDigit(caracter))
cantDig++; //cuenta los dgitos
else
if(Character.isLetter(caracter))
cantLet++; //cuenta las letras
caracter=Console.readChar("Ingrese otro caracter: ");
}
System.out.println("La Cantidad de Dgitos ingresados es: "+cantDig);
System.out.println("La Cantidad de Letras ingresadas es: "+cantLet);
}
}
La clase Integer
Cada tipo numrico tiene su propia clase de objetos. As el tipo int tiene el objeto Integer. Se han
codificado muchas funciones tiles dentro de los mtodos de la clase Integer. La misma se encuentra
en el paquete java.lang.
Veamos la diferencia:
int entero; //declara una variable entera
Integer entero=new Integer(); //declara y crea un objeto entero
Los siguientes son los atributos y mtodos de la clase Integer:
Atributos estticos Descripcin
Integer.MAX_VALUE; Mximo valor de un objeto entero.
Integer.MIN_VALUE; Mnimo valor de un objeto entero.
Carreras: Analista de Sistemas y Licenciatura en Sistemas
Asignatura: Resolucin de Problemas y Algoritmos
Docente: Lic. Vernica L. Vanoli
Apunte de Ctedra
- Pgina 143 de 165 -
Mtodos estticos Descripcin
String Integer.toString(int x) Convierte el parmetro x en un String.
String Integer.toString(int x, int base)
Convierte el primer parmetro x en string con la
base del segundo argumento.
Integer Integer.valueOf(String s) Convierte en Integer el String s.
String Integer.toBinaryString(int x)
String Integer.toOctalString(int x)
String Integer.toHexaString(int x)
Convierte a String el int x segn la base
Mtodos Descripcin
int entero.parseInt(String s) Convierte el String s en un entero.
String entero.toString( ) Retorna el valor del objeto Integer entero en un String.
int entero.intValue( ) Retorna el valor del objeto Integer entero en un int.
long entero.longValue( ) Retorna el valor del objeto Integer entero en un long.
float entero.floatValue( ) Retorna el valor del objeto Integer entero en un float.
double entero.doubleValue( ) Retorna el valor del objeto Integer entero en un double.
Veamos ejemplos de la clase Integer:
Integer.parseInt() se usa para convertir un String en un entero. Podemos especificar la base cuando
llamamos a este mtodo. Aqu tenemos un ejemplo sencillo del uso de este mtodo:
class UsoClaseInteger1
{
public static void main(String[] args)
{
int ival=Integer.parseInt("10101", 2);
System.out.println("El Valor 10101 en decimal es: "+ival);
}
}
Se puede invertir el proceso con el mtodo Integer.toString():
class UsoClaseInteger2
{
public static void main(String[] args)
{
int ival=12345;
String s=Integer.toString(ival, 2);
System.out.println("123456 en base 2: "+s);
s=Integer.toString(ival, 8);
System.out.println("123456 en base 8: "+s);
s=Integer.toString(ival,20).toUpperCase();
System.out.println("123456 en base 20: "+s);
}
}
Cuando usamos parseInt para convertir nmeros, no se acepta un prefijo como 0x para hexadecimal,
veamos un ejemplo.
Carreras: Analista de Sistemas y Licenciatura en Sistemas
Asignatura: Resolucin de Problemas y Algoritmos
Docente: Lic. Vernica L. Vanoli
Apunte de Ctedra
- Pgina 144 de 165 -
class UsoClaseInteger3
{
public static void main(String[] args)
{
Integer in=Integer.decode("0123456");
int ival=in.intValue();
System.out.println("En decimal: "+Integer.toString(ival, 10));
System.out.println("En binario: "+Integer.toString(ival, 2));
System.out.println("En hexadecimal: "+
Integer.toString(ival, 16).toUpperCase());
}
}
La clase Float
El tipo float tiene el objeto Float. Se han codificado muchas funciones tiles dentro de los mtodos de
la clase Float. La misma se encuentra en el paquete java.lang.
Veamos la diferencia:
float flotante; //declara una variable de tipo float
Float flotante=new Float(); //declara y crea un objeto de tipo float
Los siguientes son los atributos y mtodos de la clase Float:
Atributos estticos Descripcin
Float.POSITIVE_INFINITY Infinito negativo del tipo float.
Float.NEGATIVE_INFINITY Infinito positivo del tipo float.
Float.NaN Valor no-nmero.
Float.MAX_VALUE Mximo valor.
Float.MIN_VALUE Mnimo valor.
Mtodos estticos Descripcin
String Float.toString(float f) Convierte el parmetro f a un String.
float Float.valueOf(3.14) Asigna el literal a un tipo float
boolean Float.isNaN(float f)
La funcin isNaN() comprueba si el float f es un
No-Nmero. Un ejemplo de no-nmero es raz
cuadrada de -2.
boolean Float.isInfinite(float f) Comprueba si el float f es infinito.
String Float.toString(float f) Convierte el parmetro f a un String.
Mtodos Descripcin
String flotante.toString( ) Convierte el objeto Float en un String.
int flotante.intValue( ) Convierte el objeto Float en un Int.
long flotante.longValue( ) Convierte el objeto Float en un long.
float flotante.floatValue( ) Convierte el objeto Float en un float.
double flotante.doubleValue( ) Convierte el objeto Float en un double
Carreras: Analista de Sistemas y Licenciatura en Sistemas
Asignatura: Resolucin de Problemas y Algoritmos
Docente: Lic. Vernica L. Vanoli
Apunte de Ctedra
- Pgina 145 de 165 -
Veamos un ejemplo de la clase Float:
class UsoClaseFloat
{
public static void main(String[] args)
{
float f1=Console.readFloat("Ingrese un valor real: ");
Float F=new Float(2.30);
if(f1 < F.floatValue())
System.out.println(f1+" es menor que "+F.floatValue());
else
if(f1 > F.floatValue())
System.out.println(f1+" es mayor "+F.floatValue());
else
System.out.println(f1+" es igual a "+
F.floatValue());
}
}
La clase Double
El tipo double tiene el objeto Double. Se han codificado muchas funciones tiles dentro de los
mtodos de la clase Double. La misma se encuentra en el paquete java.lang.
Veamos la diferencia:
double real; //declara una variable de tipo double
Double real=new Double(); //declara y crea un objeto de tipo double
Los siguientes son los atributos y mtodos de la clase Double:
Atributos estticos Descripcin
Double.POSITIVE_INFINITY Infinito positivo del tipo Double
Double.NEGATIVE_INFINITY Infinito negativo del tipo Double
Double.NaN No-nmero
Double.MAX_VALUE Mximo valor del tipo Double
Double.MIN_VALUE Mnimo valor del tipo Double
Mtodos estticos Descripcin
boolean Double.isInfinite(double d)
boolean Double.isNaN(double d)
Retorna verdadero si es Infinito/no-nmero.
Double Double.parseDouble(String s) Convierte a Double el String s.
String Double.toString(double d) Convierte a String el double d.
Mtodos Descripcin
boolean real.isInfinite( )
boolean real.isNaN( )
Retorna verdadero si es Infinito/no-nmero.
String real.toString( )
int real.intValue( )
float real.floatValue( )
Long real.longValue( )
Retorna un Double real segn el tipo
especificado.
boolean real.equals(Object O) Compara el objeto real con el O.
Carreras: Analista de Sistemas y Licenciatura en Sistemas
Asignatura: Resolucin de Problemas y Algoritmos
Docente: Lic. Vernica L. Vanoli
Apunte de Ctedra
- Pgina 146 de 165 -
Veamos un ejemplo de la clase Double:
class UsoClaseDouble
{
public static void main(String[] args)
{
Double d1=new Double(3.14159);
Double d2=new Double("314159E-5");
if(d1.equals(d2))
System.out.println("Son Iguales");
else
System.out.println("No son Iguales");
}
}
La clase Random
Esta clase pertenece al paquete java.util. Esta clase se usa para generar una serie de nmeros
aleatorios. La clase usa una semilla de 48 bits que se modifica usando una frmula de congruencia
lineal. Si se crean dos casos de muestras al azar con la misma semilla, la sucesin de llamadas del
mtodo se hace para cada uno; ellos generarn y devolvern sucesiones idnticas de nmeros. Para que
la serie sean diferentes se debern utilizar semillas diferentes para cada una.
La semilla se inicializa cuando se crea el objeto de la clase Random. Existen dos constructores:
Random() que crea un nuevo generador de nmeros aleatorios y Random(long) que crea un nuevo
generador con una semilla para la generacin.
Suponiendo que tenemos una variable valAleatorio con la cual crearemos una instancia de la clase
Random:
valAleatorio=new Random();
entonces:
Mtodos Descripcin
valAleatorio.nextInt()
Extrae un int, distribuido uniformemente a
lo largo del rango de los enteros.
valAleatorio.nextLong()
Extrae un long, distribuido uniformemente
a lo largo del rango de long.
valAleatorio.nextFloat()
Extrae un float, distribuido uniformemente
entre 0.0 y 1.0.
valAleatorio.nextDouble()
Extrae un double, distribuido
uniformemente entre 0.0 y 1.0.
Veamos un ejemplo de la clase Random:
//es necesario importar el paquete donde se encuentra la clase
import java.util.Random;
class UsoClaseRandom
{
public static void main(String[] args)
{
Random alea=new Random();
System.out.println("Diez nmeros Random enteros");
for(int i=1; i<=10; i++)
System.out.println(alea.nextInt());
System.out.println("Cinco nmeros Random long");
Carreras: Analista de Sistemas y Licenciatura en Sistemas
Asignatura: Resolucin de Problemas y Algoritmos
Docente: Lic. Vernica L. Vanoli
Apunte de Ctedra
- Pgina 147 de 165 -
for(int i=1; i<=5; i++)
System.out.println(alea.nextLong());
}
Aclaracin: Tener en cuenta que si se ejecuta varias veces este cdigo, la serie de resultados sern
diferentes en cada caso. Ahora bien, si cuando se crea el objeto alea se utiliza el otro constructor,
por ejemplo:
Random alea=new Random(3000);
en cada ejecucin del cdigo la serie de resultados sern los mismos ya que se inicializa siempre con
la semilla 3000.
Carreras: Analista de Sistemas y Licenciatura en Sistemas
Asignatura: Resolucin de Problemas y Algoritmos
Docente: Lic. Vernica L. Vanoli
Apunte de Ctedra
- Pgina 148 de 165 -
PILAS (LIFO)
Una pila (stack) es una estructura de datos (objeto), que consta de una serie de elementos (datos), en la
cual las inserciones y eliminaciones se realizan por un extremo llamado cima (top) de la pila. La
estructura pila se conoce tambin como LIFO (Last-In First-Out: ultimo en entrar primero en salir),
que significa el ltimo elemento insertado es el primer elemento en ser sacado.
Existen numerosos casos prcticos en los que se utiliza el concepto de pila: por ejemplo, una pila de
platos, una pila de latas en un supermercado, una pila de libros que se exhiben en una librera, etc. Es
de suponer, para el primer caso, que si el cocinero necesita un plato limpio, tomar el que est encima
de todos, que es el ltimo que se coloc en la pila.
Las operaciones fundamentales de meter (push) y sacar (pop) elementos de la pila se hacen por un
extremo de la pila llamado cima o cabeza. Es decir, el acceso a la informacin de la pila tiene
restricciones.
Veamos la evolucin a partir de una pila vaca luego de diferentes operaciones de entrada y salida:
Meter a Meter b Meter c
c
cima
b
cima b
a
cima a a
Sacar Meter d Meter e
e
cima
d
cima d
b
cima b b
a a a
Sacar Sacar Sacar
d
cima
b b
cima
a a a
cima
Carreras: Analista de Sistemas y Licenciatura en Sistemas
Asignatura: Resolucin de Problemas y Algoritmos
Docente: Lic. Vernica L. Vanoli
Apunte de Ctedra
- Pgina 149 de 165 -
Sacar
cima
La pila ha
quedado
vaca
Las operaciones bsicas con las pilas son:
crear/inicializar: inicializar una pila vaca.
pila vaca: determinar si una pila esta vaca, es decir, no tiene elementos.
pila llena: determinar si una pila esta llena, es decir, si no caben ms elementos.
limpiar pila: quita todos los elementos y deja la pila vaca.
meter: inserta un elemento en la cima de la pila.
sacar: recupera y elimina el ltimo elemento en la cima de la pila.
Estas operaciones se pueden ver como los siguientes mtodos para la clase Pila:
Pila() //crea-inicializa-limpia una pila
estaVacia() //determina si la pila est o no vaca
estaLlena() //determina si la pila est o no llena
limpiar() //quita todos los elementos de la pila
meter(elem) //mete el elemento elem en la pila
sacar() //saca y devuelve un elemento de la pila
Posibles situaciones de error que se pueden presentar con las pilas:
Intentar meter un elemento en una pila llena (error de desbordamiento overflow o rebosamiento).
Forma parte de una precondicin. Entonces, antes de meter un elemento en la pila:
if(!estaLlena())
//meter el elemento
else
//mensaje
Intentar sacar un elemento en una pila vaca (error de desbordamiento negativo underflow).
Forma parte de una precondicin. Entonces antes de sacar un elemento de la pila:
if(!estaVacia())
//sacar el elemento
else
//mensaje
Implementacin de una Pila
Una pila se puede implementar mediante arreglos unidimensionales (pila esttica) o mediante listas
enlazadas (pila dinmica). Veremos el primer caso segn los siguientes niveles:
Carreras: Analista de Sistemas y Licenciatura en Sistemas
Asignatura: Resolucin de Problemas y Algoritmos
Docente: Lic. Vernica L. Vanoli
Apunte de Ctedra
- Pgina 150 de 165 -
1. Arreglos y un ndice cima: en el arreglo guardaremos los elementos de la pila; usaremos un
atributo cima para determinar el ltimo elemento, como ndice del arreglo y una constante con el
mximo nmero de elementos.
class Pila
{
private final int maxpila=100; //cantidad de elementos de la pila
private int[] elementos; //arreglo que representa a la pila
private int cima; //la cima: ltimo elemento
//constructor de la pila
public Pila()
{
elementos=new int[maxpila];
cima=-1;
}
//verifica si la pila esta o no vaca
public boolean estaVacia()
{
return (cima == -1);
}
//verifica si la pila esta o no llena
public boolean estaLlena()
{
return (cima == maxpila - 1);
}
//agrega un elemento en la pila
//precondicin: pila no llena y elemento entero
//postcondicin: elemento entero cargado a la pila si no est llena
public void meter(int elem)
{
if(!estaLlena())
{
cima++;
elementos[cima]=elem;
}
return;
}
//saca un elemento del tope de la pila
//precondicin: pila no vaca
//postcondicin: elemento entero sacado de la pila si no est vaca
public int sacar()
{
int aux=Integer.MIN_VALUE; //-2147483648
if(!estaVacia())
{
aux=elementos[cima];
cima--;
}
return aux;
}
}
Carreras: Analista de Sistemas y Licenciatura en Sistemas
Asignatura: Resolucin de Problemas y Algoritmos
Docente: Lic. Vernica L. Vanoli
Apunte de Ctedra
- Pgina 151 de 165 -
La desventaja de esta implementacin es que la pila solo puede ser de tipo entero.
2. Arreglo nicamente: en esta implementacin se utiliza un arreglo que tiene de 0 a maxpila
elementos, aprovechando la posicin 0 del arreglo para llevar la cima.
class Pila
{
private final int maxpila=100; //cantidad de elementos de la pila
private int[] elementos; //arreglo que representa a la pila
private final int cima=0; //la cima: ltimo elemento
//constructor de la pila
public Pila()
{
elementos=new int[maxpila];
elementos[cima]=0;
}
//verifica si la pila esta o no vaca
public boolean estaVacia()
{
return (elementos[cima] == 0);
}
//verifica si la pila esta o no llena
public boolean estaLlena()
{
return (elementos[cima] == maxpila - 1);
}
//mete un elemento en la pila
//precondicin: pila no llena y elemento entero
//postcondicin: elemento entero metido en la pila si no est llena
public void meter(int elem)
{
if(!estaLlena())
{
elementos[cima]++;
elementos[elementos[cima]]=elem;
}
return;
}
//saca un elemento del tope de la pila
//precondicin: pila no vaca
//postcondicin: elemento entero sacado de la pila si no est vaca
public int sacar()
{
int aux=Integer.MIN_VALUE; //-2147483648
if(!estaVacia())
{
aux=elementos[elementos[cima]];
elementos[cima]--;
}
return aux;
Carreras: Analista de Sistemas y Licenciatura en Sistemas
Asignatura: Resolucin de Problemas y Algoritmos
Docente: Lic. Vernica L. Vanoli
Apunte de Ctedra
- Pgina 152 de 165 -
}
}
Las desventajas de esta implementacin es que la pila solo puede ser de tipo entero y de la cantidad
mxima de elementos se roba un espacio para la cima.
IMPORTANTE: En teora, el tamao de una pila no esta limitado ms que por el espacio en
memoria, en estas implementaciones como hemos utilizado arreglo (asignacin esttica de memoria)
estamos restringidos al lmite predefinido de los arreglos, ms adelante veremos como implementar
una pila y no preocuparnos por esto.
Pese a la similitud, es preciso notar que la pila no es igual que un vector. Una pila es, por esencia, un
objeto dinmico mientras que un vector tiene un nmero mximo de elementos, determinado por su
definicin.
Carreras: Analista de Sistemas y Licenciatura en Sistemas
Asignatura: Resolucin de Problemas y Algoritmos
Docente: Lic. Vernica L. Vanoli
Apunte de Ctedra
- Pgina 153 de 165 -
COLAS (FIFO)
El diccionario de la Real Academia Espaola define una acepcin de cola como hilera de personas
que esperan turno para alguna cosa: una hilera de vehculos esperando pasar una frontera, una hilera
de personas para entrar en un cine, una hilera de personas en la caja de un supermercado, la cola de los
bancos en las que los clientes esperan para ser atendidos o una cola de trabajos en un sistema de
computadoras que espera la disponibilidad de algn dispositivo de salida tal como una impresora.
En cada uno de estos ejemplos, los elementos se atienden en el orden que llegaron; es decir, el primer
elemento en entrar (primero en la cola) es el primero en ser atendido (salir). Por consiguiente, una cola
es una estructura FIFO (First-In First-Out: primero en entrar primero en salir), tambin llamada a
veces estructura FCFS (First-Come First-Served: primero que llega primero que se atiende).
Una cola (Queue) es una estructura de datos (objeto) sobre la cual se aplican las operaciones bsicas
de aadir y eliminar elementos por un extremo de la cola. Los elementos se borran por un extremo
llamado frente y se insertan por un extremo llamado ltimo.
Veamos la evolucin de la siguiente cola:
frente
ultimo
frente
ultimo
frente ultimo
a a b
Cola vaca Insertar a Insertar b
frente ultimo
frente ultimo
frente
ultimo
a b c b c c
Insertar c Borrar Borrar
frente ultimo
frente ultimo
frente ultimo
c d c d e d e
Insertar d Insertar e Borrar
Las operaciones bsicas con las colas son:
crear/inicializar: inicializar una cola vaca.
cola vaca: determinar si una cola esta vaca.
cola llena: determinar si una cola esta llena.
limpiar cola: quita todos los elementos y deja la cola vaca.
insertar: aade un elemento a la parte ltima de la cola.
borrar: recupera y elimina el elemento al frente de la cola.
Estas operaciones se pueden ver como los siguientes mtodos para la clase Cola:
Cola() //crea-inicializa-limpia una cola
estaVacia() //determina si la cola est o no vaca
Carreras: Analista de Sistemas y Licenciatura en Sistemas
Asignatura: Resolucin de Problemas y Algoritmos
Docente: Lic. Vernica L. Vanoli
Apunte de Ctedra
- Pgina 154 de 165 -
estaLlena() //determina si la cola est o no llena
limpiar() //quita todos los elementos de la cola
insertar(elem) //inserta el elemento elem en la cola
borrar() //borra y devuelve un elemento de la cola
Posibles situaciones de error que se pueden presentar con las colas:
Intentar insertar un elemento en una cola llena. Forma parte de una precondicin. Entonces, antes de
insertar un elemento en la cola:
if(!estaLlena())
//insertar el elemento
else
//mensaje
Intentar borrar un elemento en una cola vaca. Forma parte de una precondicin. Entonces antes de
borrar un elemento de la cola:
if(!estaVacia())
//borrar el elemento
else
//mensaje
Implementacin de una Cola
Al igual que las pilas, las colas se pueden implementar utilizando arreglos o listas enlazadas. Veremos
tambin el primer caso segn los siguientes niveles:
1. Frente fijo y ltimo movible: esta solucin es similar a la pila. En los siguientes esquemas se
representa las distintas situaciones. El frente (subndice del arreglo) debe estar siempre fijo (en 0),
se insertan elementos por el ltimo (subndice) y cuando se borran elementos de la cola, para
poder mantener la premisa del frente fijo, ser necesario desplazar los elementos restantes de la
cola. La ventaja de este diseo es su simplicidad, dado que se utilizan prcticamente los mismos
algoritmos que para una pila. La desventaja es tener que mover todos los elementos de la cola cada
vez que se borra un elemento de la cola.
2. Frente y ultimo movibles o flotantes (colas circulares): La desventaja de la implementacin
anterior se puede resolver llevando un ndice para el frente al igual que para el ultimo y mantener
ambos extremos flotantes. La operacin de insertar sigue siendo la misma, incrementando el
ltimo. La operacin de suprimir, en este caso incrementara el frente. Pero se plantea un
problema: cuando el ndice ltimo llega al ltimo elemento del arreglo, podramos pensar que la
cola esta llena, sin embargo es posible que no sea as. Para ello, trataremos al arreglo como una
estructura circular (Figura 1.a). Es decir, el elemento que le sigue al ltimo es el primero. Para
obtener la siguiente posicin del ltimo, utilizamos el siguiente mtodo:
private int siguiente(int subind)
{
if(subind = = maxcola -1)
return 0;
else
return subind++;
}
Carreras: Analista de Sistemas y Licenciatura en Sistemas
Asignatura: Resolucin de Problemas y Algoritmos
Docente: Lic. Vernica L. Vanoli
Apunte de Ctedra
- Pgina 155 de 165 -
Pero ahora se nos plantea un nuevo problema: Cmo sabemos si la cola esta llena o vaca?. Para
ello, el atributo frente indica la posicin del arreglo que precede al primer elemento de la cola,
en lugar del ndice al propio elemento frente. Y el atributo ltimo es la posicin en donde se hizo
la ltima insercin, ltimo elemento de la cola. Se avanza en el sentido de las agujas del reloj.
La cola estar vaca cuando ambos ndices sean iguales (Figura 1.b). La cola estar llena cuando el
siguiente al ltimo sea igual al frente. Para insertar un elemento a la cola se debe: incrementar el
ltimo y agregar el elemento (Figura 1.c). Para borrar un elemento de la cola se debe: incrementar
el frente.
Figura 1: a) cola circular; b) cola circular vaca; c) cola circular que contiene un elemento.
class Cola
{
private final int maxcola=50; //cantidad de elementos de la cola
private int[] elementos; //arreglo que representa a la cola
private int frente, ultimo; //ndices para insertar y borrar
// Constructor de la cola
public Cola()
{
elementos=new int[maxcola];
frente=0;
ultimo=0;
}
//verifica si la cola esta o no vaca
public boolean estaVacia()
{
return (ultimo == frente);
}
//verifica si la cola esta o no llena
public boolean estaLlena()
{
int sigultimo=siguiente(ultimo);
return (sigultimo == frente);
}
n-1 0
1
2
n-1
0
1
0
1
n-1
frente
ultimo
frente
ultimo
Carreras: Analista de Sistemas y Licenciatura en Sistemas
Asignatura: Resolucin de Problemas y Algoritmos
Docente: Lic. Vernica L. Vanoli
Apunte de Ctedra
- Pgina 156 de 165 -
//establece cul es el siguiente elemento
private int siguiente(int subind)
{
if(subind == maxcola - 1)
return 0;
else
return ++subind;
}
//inserta un elemento en la cola
//precondicin: cola no llena y elemento entero
//postcondicin: elemento entero insertado en cola si no est llena
public void insertar(int elem)
{
if(!estaLlena())
{
ultimo=siguiente(ultimo);
elementos[ultimo]=elem;
}
return;
}
//borra un elemento de la cola
//precondicin: cola no vaca
//postcondicin: elemento entero borrado de la cola si no est vaca
public int borrar()
{
if(!estaVacia())
{
frente=siguiente(frente);
return elementos[frente];
}
else
return Integer.MIN_VALUE; //-2147483648
}
}
Aplicaciones de las colas
Las colas se utilizan con frecuencia en informtica, siempre que ms de un proceso requiera un recurso
especfico, tal como una impresora, una unidad de disco o la unidad central de proceso. Tal proceso, al
solicitar un recurso especfico, se sita en una cola a la espera de atender a ese proceso. Por ejemplo:
diferentes computadoras pueden compartir la misma impresora, y una cola spool se utiliza para
planificar las diferentes salidas. Si una peticin de impresin llega y la impresora esta libre
inmediatamente pasa a impresin, mientras se este imprimiendo las peticiones que lleguen sern
almacenadas en la cola spool y a medida que la impresora termine sern realizadas, liberando la cola
spool.
Otro uso importante de las colas, es para las operaciones de entrada/salida de buffers. Los buffers son
memorias intermedias que se comportan como colas entre los dispositivos de E/S y memoria principal.
Otro uso, es la CPU de un sistema operativo multiusuario, trabaja como una cola, cuando distintos
usuarios (workstation) solicitan procesos, van entrando a una cola de procesos y saliendo a medida que
el procesador va ejecutndolos (segn las prioridades). Esto se conoce como colas de prioridad.
Carreras: Analista de Sistemas y Licenciatura en Sistemas
Asignatura: Resolucin de Problemas y Algoritmos
Docente: Lic. Vernica L. Vanoli
Apunte de Ctedra
- Pgina 157 de 165 -
RECURSIVIDAD
La recursividad es una tcnica de programacin muy potente que puede ser utilizada en lugar de la
iteracin (bucles). Ello implica una forma diferente de ver las acciones repetitivas, permitiendo que un
subprograma se llame as mismo para resolver una versin ms pequea de su problema original.
Algunas definiciones de recursividad:
Recursin: ver recursividad.
Un objeto es recursivo si figura en su propia definicin.
Una definicin recursiva es aquella en la que el objeto que se define forma parte de la definicin.
Veamos un ejemplo:
Analicemos la definicin matemtica del factorial de N (N!).
N = 5
N! = N * (N-1) * (N-2) * (N-3) * * (N-(N-1))
5! = 5 * (5-1) * (5-2) * (5-3) * (5-4)
5! = 5 * 4 * 3 * 2 * 1
5! = 120
El mtodo para calcular el factorial es el siguiente:
public int factorial(int N)
{
//declaracin de variables locales
int cont, fact;
//clculo
fact=1;
for(cont=2; cont<=N; cont++)
fact=fact * cont;
return fact;
}
Puede verse tambin como que 5! es igual a 5 * 4!
Generalizando N!:
1
N * (N - 1)!
si N = 0
si N > 0
Esta generalizacin es una definicin recursiva donde:
1. La condicin de salida es: N = 0 (denominado CASO BASE)
2. La parte recursiva es: N! = N * (N - 1)! (denominado CASO GENERAL)
Entonces, podemos afirmar que esta funcin es recursiva, dado que puede ser expresada en funcin de
si misma, es decir: factorial(N) = N * factorial(N - 1)
Por lo tanto, la solucin recursiva sera:
public int factorial(int valor)
{
if(valor == 0)
return 1;
else
return valor * factorial(valor - 1);
}
Carreras: Analista de Sistemas y Licenciatura en Sistemas
Asignatura: Resolucin de Problemas y Algoritmos
Docente: Lic. Vernica L. Vanoli
Apunte de Ctedra
- Pgina 158 de 165 -
Si la llamada es factorial(3) esto se ejecuta de la siguiente manera:
1er. llamada: N != 0
factorial = 3 * factorial(2)
2da. llamada: N != 0
factorial = 2 * factorial(1)
3er. llamada: N != 0
factorial = 1 * factorial(0)
4ta. llamada: N = = 0
factorial = 1
*** Vuelve hacia atrs ***
3er. llamada: factorial = 1 * 1 = 1
2da.llamada: factorial = 2 * 1 = 2
1er. llamada: factorial = 3 * 2 = 6
Por lo tanto, factorial(3) = 6
Suponiendo que la llamada se genere de la siguiente manera:
y = factorial(3);
Lo que se hace, es ir guardando todas las llamadas sin resolver en una pila, cuando llega a una que
tiene solucin comienza a extraer de la pila las llamadas y a resolverlas.
Este tipo de recorrido para comprobar la validez de un algoritmo recursivo consume tiempo. Existe
una tcnica que sirve para verificar o comprobar si una solucin o algoritmo se puede implementar en
Carreras: Analista de Sistemas y Licenciatura en Sistemas
Asignatura: Resolucin de Problemas y Algoritmos
Docente: Lic. Vernica L. Vanoli
Apunte de Ctedra
- Pgina 159 de 165 -
forma recursiva, puesto que la traza consume tiempo, es confusa y tediosa. Esta tcnica nos ayuda
inductivamente a determinar si un algoritmo recursivo funciona o no, y se denomina mtodo de las
tres preguntas.
El Mtodo de las Tres Preguntas
Para comprobar que una solucin recursiva funciona debe ser capaz de contestar SI a estas tres
preguntas:
La pregunta CASO BASE: Hay una salida no recursiva de la funcin?. La rutina funciona
correctamente para este caso base?.
CASO BASE: Instancia que se puede resolver sin hacer llamadas recursivas. Toda llamada recursiva
debe tender hacia un CASO BASE.
La pregunta LLAMADOR MAS PEQUEO: Cada llamada recursiva a la funcin se refiere a un
caso ms pequeo del problema original?.
La respuesta a esta pregunta debe buscarse en los parmetros pasados en la llamada recursiva.
La pregunta CASO GENERAL: Suponiendo que la(s) llamada(s) recursivas funcionan
correctamente, funciona correctamente todo la funcin?.
Apliquemos estas preguntas a la funcin factorial:
La pregunta CASO BASE: la respuesta es SI, cuando N=0 se produce el CASO BASE.
La pregunta LLAMADOR MAS PEQUEO: la respuesta es SI, esta dado por el parmetro de la
llamada (N-1).
La pregunta CASO GENERAL: la respuesta es SI, dado que hemos implementado la funcin de
acuerdo a su definicin matemtica o frmula N * (N-1)!
Escritura de Algoritmos (Mtodos) Recursivos
1) Obtener una definicin exacta del problema a resolver.
2) Determinar el tamao del problema completo que hay que resolver. Este tamao determinar los
valores de los parmetros en la llamada inicial a la funcin.
3) Resolver el CASO BASE donde el problema puede expresarse no recursivamente. Asegurando la
respuesta SI a la pregunta CASO BASE.
4) Resolver el CASO GENERAL correctamente en trminos de un caso ms pequeo del mismo
problema (una llamada recursiva). Esto asegurar una respuesta SI a las preguntas LLAMADOR MAS
PEQUEO y CASO GENERAL.
La Eficiencia (Iteracin vs. Recursividad)
La recursividad parece un mtodo simple para resolver problemas mediante relaciones recursivas; sin
embargo, en ocasiones se puede volver un mtodo ineficiente ya que se realizan ms clculos que su
equivalente solucin repetitiva.
Por ejemplo, supongamos que utilizamos un algoritmo recursivo para hallar un valor en un arreglo de
100 elementos. Cada vez que se invoca al mtodo, se hacen copias de todos los parmetros, anidando
ms y ms niveles de llamadas recursivas. Si el valor buscado no se halla en el vector, en un momento
tendremos 100 copias del arreglo de 100 elementos en memoria. Con el tiempo, podemos agotar la
memoria.
La eficacia de una solucin recursiva viene medida por una serie de factores, entre otros se destacan:
Tiempo de ejecucin: Se consideran ms eficientes aquellos algoritmos que cumplen con la
especificacin del problema en el menor tiempo posible.
Espacio en memoria ocupado por el algoritmo: Sern eficientes los algoritmos que utilicen las
estructuras de datos adecuadas, a fin de minimizar la memoria ocupada.
Carreras: Analista de Sistemas y Licenciatura en Sistemas
Asignatura: Resolucin de Problemas y Algoritmos
Docente: Lic. Vernica L. Vanoli
Apunte de Ctedra
- Pgina 160 de 165 -
Legibilidad y facilidad de comprensin: Mayor sencillez al momento de interpretar el algoritmo.
Desde el punto de vista de la ejecucin, los algoritmos recursivos son ms lentos y ocupan mayor
espacio en memoria, con el inconveniente que puede suponer en el caso de poca memoria. Sin
embargo, en ciertos problemas, la recursividad conduce a soluciones que son mucho ms fciles de
leer y comprender que su correspondiente solucin iterativa; en estos casos la ganancia en claridad
puede compensar con creces el costo de tiempo y espacio en memoria de la ejecucin de programas
recursivos.
Las definiciones recursivas se caracterizan por su elegancia y simplicidad en contraste con la
dificultad y falta de claridad de las definiciones repetitivas.
La solucin recursiva es estticamente ms agradable, y una vez acostumbrado, la forma recursiva es
normalmente ms fcil de leer y comprender que la forma iterativa.
Como gua general, si la solucin no recursiva es ms corta - o no mucho ms larga - que la versin
recursiva, no utilizar recursividad. Por ejemplo, el caso del factorial.
Veamos un cuadro comparativo entre las dos soluciones:
Solucin Iterativa Solucin Recursiva
Utiliza una construccin cclica
(for, while, do-while)
Utiliza una estructura de ramificacin
(if-else)
Necesita variables locales
(contadores)
Utiliza los parmetros de la funcin para
dar toda su informacin
Los datos utilizados para el ciclo son
inicializados antes del mismo
(dentro de la rutina)
Los datos utilizados son, usualmente,
inicializados en la eleccin del valor del
parmetro en la llamada inicial
Son ms largos
(ms lneas de cdigo)
Son ms cortos
(menos lneas de cdigo)
Formas y Tipos de Recursividad
Existen dos formas de recursividad:
a) Directa: la funcin se llama directamente a s mismo.
b) Indirecta: un mtodo llama otro mtodo, y ste, en algn momento, llama nuevamente al primero.
Existen tres tipos de recursividad
1) Recursividad simple. Es todo algoritmo en el cual solo aparece una llamada recursiva. Este caso
fcilmente se transforma en iteracin
AlgoritmoRecursivo(parmetros)
{
if(caso base)
[fin]
else //caso general
AlgoritmoRecursivo(llamador_ms_pequeo)
}
Carreras: Analista de Sistemas y Licenciatura en Sistemas
Asignatura: Resolucin de Problemas y Algoritmos
Docente: Lic. Vernica L. Vanoli
Apunte de Ctedra
- Pgina 161 de 165 -
2) Recursividad mltiple. Se presenta cuando existe ms de una llamada a si mismo dentro del cuerpo
del algoritmo. Este caso es ms complicado para transformar en una iteracin.
AlgoritmoRecursivo(parmetros)
{
if(caso base)
[fin]
else //caso general
AlgoritmoRecursivo(llamador_ms_pequeo),
AlgoritmoRecursivo(llamador_ms_pequeo)
}
3) Recursividad anidada. Es el caso donde existe ms de un caso general.
AlgoritmoRecursivo(parmetros)
{
if(caso base)
[fin]
else
if(caso general)
AlgoritmoRecursivo(llamador_ms_pequeo)
else
AlgoritmoRecursivo(llamador_ms_pequeo)
}
Ejemplos.
1. El siguiente mtodo muestra los elementos de un vector en orden inverso.
//ultimo: posicin del ltimo elemento (dimension-1)
public void invertirVector(int[] vector, int ultimo)
{
if(ultimo == 0)
System.out.println(vector[0]);
else
{
System.out.println(vector[ultimo]);
invertirVector(vector, ultimo - 1);
}
return;
}
2. El siguiente mtodo devuelve la suma de los elementos de un vector.
public int sumatoriaVector(int[] vector, int ultimo)
{
if(ultimo == 0)
return vector[0];
else
return (vector[ultimo] + sumatoriaVector(vector, ultimo - 1));
}
Carreras: Analista de Sistemas y Licenciatura en Sistemas
Asignatura: Resolucin de Problemas y Algoritmos
Docente: Lic. Vernica L. Vanoli
Apunte de Ctedra
- Pgina 162 de 165 -
La misma solucin con distinto algoritmo:
//primero: posicin del primer elemento (0)
public int sumatoriaVector(int[] vector, int primero)
{
if(primero == dimension - 1)
return vector[primero];
else
return (vector[primero] + sumatoriaVector(vector, primero+1));
}
Carreras: Analista de Sistemas y Licenciatura en Sistemas
Asignatura: Resolucin de Problemas y Algoritmos
Docente: Lic. Vernica L. Vanoli
Apunte de Ctedra
- Pgina 163 de 165 -
ANEXO: Los Lenguajes de Programacin
Para que un procesador realice un proceso, se le debe suministrar en primer lugar un algoritmo
adecuado. El procesador debe ser capaz de interpretar el algoritmo, lo que significa:
comprender las instrucciones de cada paso.
realizar las operaciones correspondientes.
Cuando el procesador es la computadora, el algoritmo se ha de expresar en un formato que se
denomina programa. Un programa se escribe en un lenguaje de programacin y las operaciones que
conducen a expresar un algoritmo en forma de programa se llaman programacin.
Instrucciones a la computadora
Los diferentes pasos de un algoritmo se expresan en los programas como instrucciones. Por
consiguiente, un programa consta de una secuencia de instrucciones, cada una de las cuales
especifican ciertas operaciones que debe ejecutar la computadora.
Las instrucciones bsicas y comunes a casi todos los lenguajes de programacin se pueden agrupar en:
Instrucciones de entrada/salida: Instrucciones de transferencia de informacin y datos, entre los
dispositivos perifricos (teclado, impresora, unidad de disco, etc.) y la memoria central.
Instrucciones aritmtico-lgicas: Instrucciones que ejecutan operaciones aritmticas (suma, resta,
multiplicacin, divisin, potenciacin), lgicas (operaciones &, |, etc.).
Instrucciones selectivas: Instrucciones que permiten la seleccin de tareas alternativas en funcin
de los resultados de diferentes expresiones condicionales.
Instrucciones repetitivas: Instrucciones que permiten la repeticin de secuencias de instrucciones
un nmero determinado o indeterminado de veces.
Principales tipos de lenguajes utilizados en la actualidad
1. Lenguajes Mquina.
Son aquellos que estn escritos en lenguajes directamente inteligibles por la mquina (computadora),
ya que sus instrucciones son cadenas binarias (cadenas o series de caracteres dgitos- 0 y 1) que
especifican una operacin, y las posiciones (direccin) de memoria implicadas en la operacin se
denominan instrucciones de mquina o cdigo mquina. El cdigo mquina es el conocido cdigo
binario.
Las instrucciones en lenguaje mquina dependen del hardware de la computadora y, por lo tanto,
diferirn de una computadora a otra.
Ventajas:
Posibilidad de cargar (transferir un programa a memoria) sin necesidad de traduccin posterior, lo que
supone una velocidad de ejecucin superior a cualquier otro lenguaje de programacin.
Desventajas:
Dificultad y lentitud en la codificacin.
Poca fiabilidad.
Dificultad de verificar y poner a punto los programas.
Los programas slo son ejecutables en el mismo procesador (UCP).
2. Lenguajes de Bajo Nivel.
Son ms fciles de usar, pero al igual que los lenguajes mquina, dependen de la mquina en
particular. El lenguaje de bajo nivel por excelencia es el ensamblador (Assembly Language).
Carreras: Analista de Sistemas y Licenciatura en Sistemas
Asignatura: Resolucin de Problemas y Algoritmos
Docente: Lic. Vernica L. Vanoli
Apunte de Ctedra
- Pgina 164 de 165 -
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 mquina se conoce como programa objeto, ya directamente inteligible por la
computadora.
Ventaja:
Respecto a los lenguajes mquina:
Mayor facilidad de codificacin.
Mayor velocidad de clculo.
Desventajas:
Dependencia total de la mquina, lo que impide la transportabilidad de los programas.
La formacin de los programadores es ms compleja que la correspondiente a los programadores
de alto nivel, ya que exige no slo las tcnicas de programacin, sino tambin el conocimiento del
interior de la mquina.
3. Lenguajes de Alto Nivel.
Son los ms utilizados por los programadores. Un programa escrito en un lenguaje de alto nivel es
independiente de la mquina, esto es, las instrucciones del programa no dependen del diseo del
hardware o de una computadora 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.
Los programas fuentes tienen que ser traducidos por programas traductores llamados en este caso
compiladores e intrpretes.
Los lenguajes de alto nivel existentes son muy numerosos, algunos de ellos son: Java, Pascal, C, C++,
Cobol, Fortran, Basic, VisualBasic, Clipper, Prolog, Delphi, Lisp, etc.
Intrprete: es un traductor que toma un programa fuente, lo traduce y a continuacin lo ejecuta.
Compilador: es un programa que traduce los programas fuente escritos en lenguajes de alto nivel a
lenguaje mquina.
Los programas escritos en lenguaje de alto nivel se llaman programas fuente y el programa traducido
programa objeto. El programa objeto obtenido de la compilacin (proceso de traduccin) ha sido
traducido normalmente a cdigo mquina. 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.
Carreras: Analista de Sistemas y Licenciatura en Sistemas
Asignatura: Resolucin de Problemas y Algoritmos
Docente: Lic. Vernica L. Vanoli
Apunte de Ctedra
- Pgina 165 de 165 -
BIBLIOGRAFIA
1. Algoritmos + Estructuras de Datos = Programas. Nicklaus Wirth. Prentice Hall. 1989.
2. Algoritmos, Datos y Programas: Conceptos Bsicos. Armando De Giusti, Cristina Madoz,
Rodolfo Bertone, Marcelo Naiouf, Laura Lanzarini, Gladys Gorga y Claudia Russo. Editorial Exacta.
Argentina. 1998.
3. Cmo Programar en JAVA. Harvey M. Deitel y Paul J. Deitel. Prentice Hall. Mxico. 1997.
4. Construccin de Software Orientado a Objetos. Bertrand Meyer. Prentice Hall. Segunda edicin.
Espaa. 1999.
5. Core JAVA Volume I-Fundamentals. Cay S. Horstmann y Gary Cornell. The Sun Microsystem
Press JAVA Series. 1999.
6. El Lenguaje de Programacin JAVA. Ken Arnold, James Gosling y David Holmes. Addison
Wesley. Tercera edicin. 2001.
7. Estructuras de Datos. Osvaldo Cair y Silvia Guardati. Mc. Graw Hill. Tercera edicin. Mxico.
2006.
8. Estructuras de Datos: Algoritmos, Abstraccin y Objetos. Luis Joyanes Aguilar e Ignacio
Zahonero Martnez. Mc. Graw Hill. Espaa. 1998.
9. Estructuras de Datos en Java. Mark Allen Weiss. Addison Wesley. Espaa. 1998.
10. Estructuras de datos y algoritmos. Alfred Aho, John Hopcroft y Jeffrey Ullman. Addison-
Wesley. Estados Unidos. 1988.
11. Fundamentos De Programacin. Luis Joyanes Aguilar. Mc Graw Hill. Espaa. 1996.
12. Introduccin a la Programacin Orientada a Objetos con Java. C. Thomas Wu. Mc. Graw Hill.
Espaa. 2001.
13. Pascal. Nell Dale y Chip Weems. Mc. Graw Hill. 2da. Edicin. 1989.
14. Pascal. Introduccin al lenguaje y resolucin de problemas con programacin estructurada.
Elliot B. Koffman. Addison Wesley. 1986.
15. Pascal y Estructuras de Datos. Neil Dale y Susan Lilly. Mc. Graw Hill. Segunda edicin.
Mxico. 1992
16. Programacin con C++. Al Stevens y Clayton Walnum. Anaya. 2000.
17. Programacin en Java 2. Algoritmos, Estructuras de Datos y Programacin Orientada a Objetos.
Luis Joyanes Aguilar e Ignacio Zahonero Martnez. Mc. Graw Hill. Espaa. 2002.