logica_programacion (nueva ventana)

Anuncio
Fase análisis
ra
g
o
r
p
a
l
e
d
a
c
i
g
gramación Ló
o
Lógica de la pr
Año 2012 - Edición 01
Lógica de la programación
og ra m ac ió n
Ló gi ca de la pr
ón
ci
a
m
a
r
g
o
r
p
e
lógica d
Solución de problemas
Introducción
Fase de Análisis
a la programación
yecto
Actividad de pro
RequerimienDefinición de
tos del Cliente
de los elemenIdentificación
ra proyectos
tos de diseño pa
multimedia
Estructuras repetitivas
Estructuras de datos
Herramientas para
la simulación
Sena
Producción en multimedia
Actividad de
aprendizaje
Estructuras selectivas
Fase Análisis
Sena Producción en multimedia
1
id o
Ta bl a de co nt en
id o
Ta bl a de co nt en
Contenido Lógica de la programación
01
02
03
04
Solución de problemas
Introducción a la
Estructuras selectivas
Estructuras repetitivas
3.1. Si Entonces (If Then)
4.1. Mientras que (While)
3.2. Si Entonces Sino (If Then Else)
4.2. Repetir para (For)
3.3. Si Anidado
4.3. Hacer mientras (Do … while)
1.1. Introducción a la solución de problemas: Características, pasos para resolverlos,
estrategia para mejorar la compresión del
enunciado de un problema y las variables e
identificación de los datos de un problema
1.2. Relación entre variables y características: Relaciones parte-todo, de orden, con
inversiones, con inversiones de orden y
familiares.
programación
2.1. Conceptos generales
2.2. Algoritmos y diagramas de flujo
2.3. Conceptos fundamentales
3.4. Si Multiple (Case)
2.4. Construcción de Algoritmos y Diagramas de flujo
page
36
page
27
page
11
1.3. Problemas acerca de las relaciones entre dos variables: tablas numéricas, lógicas
y conceptuales.
page
05
05
06
Estructuras de datos
Herramientas para la
(Arreglos)
simulación
5.1. Arreglos en una dimensión o Vectores
6.1. Pseudocódigo LPP
page
59
page
60
5.2. Arreglos multidimensionales o Matrices
Bibliografía
6.2. Diagramas de flujo DFD
Este material puede ser distribuido, copiado y exhibido por terceros si se mues-
Glosario
page
page
44
57
page
61
Créditos
tra en los créditos. No se puede obtener
ningún beneficio comercial y las obras
2
derivadas tienen que estar bajo los misSena Producción en multimedia
mos términos de licencia que el trabajo
original.
Fase Análisis
Fase Análisis
Sena Producción en multimedia
3
a
l
e
d
a
c
i
g
Ló
n
ó
i
c
a
m
a
r
prog
In tro du cc ió n
01
tructuras
s
E
,
n
ió
c
a
m
a
r
ulación
lemas, prog
b
im
o
s
r
a
p
r
e
a
d
p
a
n
t
ió
n
c
ie
Solu
tos, herram
a
d
y
s
a
iv
it
t
e
p
selectivas, re
01
Solución de Problemas
1.1. Introducción a la solución de problemas:
Características, pasos para resolverlos, estrategia
para mejorar la compresión del enunciado de un
problema y las variables e identificación de los
datos de un problema
02
Introducción a la programación
2.1. Conceptos generales
Solución de Problemas
1.1.Introducción a la
solución de problemas:
C
aracterísticas, pasos para resolverlos,
estrategia para mejorar la compresión
del enunciado de un problema y las variables e identificación de los datos de un problema.
2.2. Algoritmos y diagramas de flujo
2.3. Conceptos fundamentales
2.4. Construcción de Algoritmos y Diagramas
de flujo.
1.2. Relación entre variables y características:
Relaciones parte-todo, de orden, con inversiones,
con inversiones de orden y familiares.
ob le m as
So lu ci ón de pr
03
Estructuras Selectivas
3.1. Si Entonces (If Then)
3.2. Si Entonces Sino (If Then Else)
1.3. Problemas acerca de las relaciones entre dos
variables: tablas numéricas, lógicas y conceptuales.
3.3. Si Anidado
Un problema es un enunciado en el cual se
da cierta información y se plantea una pregunta que debe ser respondida; en general se pide
calcular o indagar uno o más datos faltantes o
generar explicaciones acerca de ciertos hechos
o situaciones.
3.4. Si Multiple (Case)
04
Estructuras Repetitivas
4.1. Mientras que (While)
4.2. Repetir para (For)
4.3. Hacer mientras (Do … while)
05
Estructuras de Datos (Arreglos)
5.1. Arreglos en una dimensión o Vectores
5.2. Arreglos multidimensionales
06
Con frecuencia la solución de problemas ha estado rodeada de mitos y creencias que obstaculizan el aprendizaje, se atribuyen a los problemas
dificultades no justificadas que, más bien, surgen
de la falta de información acerca de lo que es
un problema y de la variedad de estrategas que
pueden utilizarse para resolverlos.
Herramientas para la Simulación
Todo problema involucra una discrepancia o
diferencia entre dos situaciones, una observada o dada y otra deseada. Resolver el problema
es encontrar la manera de reducir o eliminar la
discrepancia.
Con frecuencia la solución de
problemas ha estado rodeada de
mitos y creencias que obstaculizan
el aprendizaje
Tipos de Problemas
De acuerdo con la naturaleza de la información que se da o se proporciona, los problemas
se dividen en dos tipos: estructurados y no estructurados. En el primer tipo se proporciona la
información necesaria y suficiente para encontrar la solución, y en el segundo la información
es incompleta o ambigua y debe complementarse
con datos adicionales.
Etapas para resolver un problema
Para llegar a la solución de un problema la
persona debe, en primer lugar; leer cuidadosamente el enunciado, codificar toda la información dada e identificar la información relevante
y las pistas que se dan. Este proceso contribuye a lograr una clara imagen o representación
mental del problema y es básica para alcanzar
la segunda etapa durante el proceso de solución
de un problema.
6.1. Pseudocodigo LPP
6.2. Diagramas de flujo DFD
4
Sena Producción en multimedia
Fase Análisis
Fase Análisis
Sena Producción en multimedia
5
o
S
s
a
m
e
l
b
o
r
n de p
ob le m as
So lu ci ón de pr
Una estrategia es un conjunto ordenado
de pasos que permite lograr un objetivo.
ob le m as
So lu ci ón de pr
Estrategia para mejorar la comprensión
del enunciado de un problema:
componentes de un problema
Características de los problemas
Un problema es un enunciado acerca de una
situación determina en el cual se dan datos o información y se plantea una pregunta acerca de
una discrepancia o un desequilibrio entre una situación observada o dada y una situación deseada. La respuesta a la pregunta proporciona los
datos para reducir la discrepancia y constituye
la solución el problema.
Problemas Estructurados y
Problemas no Estructurados
Problemas no estructurados
La información dada no es suficiente
Identificación de las
características del
enunciado de un problema.
Estructurados
La información dada es la
necesaria y suficiente
a. Estado inicial: condición de partida.
b. Estados intermedios: diferente etapas
intermedia que deben completarse para
resolver el problema.
c. Estado final: condición de llegada
determinada por lo que se pide en el
enunciado del problema.
d. Operaciones:
diferentes
acciones,
actividades o procesos sugeridos en el
problema.
e. Condiciones: requerimientos o condiciones
que se imponen en el enunciado
f. Pregunta: lo que se desea saber o se
cuestiona en el problema
Un problema es un enunciado en el cual se plantean
datos iniciales y finales, se describen algunas
acciones realizadas, se establecen restricciones
(si existen) y se plantea una pregunta acerca de
uno o más datos faltantes. Resolver el problema
es encontrar el o los datos faltantes.
Componentes de un problema
Estrategia general y específica
Datos Iniciales Estado inicial
Datos finales Estado final
En este caso, dentro de la estrategia general
utilizamos además dos estrategias particulares
o específicas:
¿Cuántos jóvenes han recibido los
beneficios del plan de renovación de
la educación del país Colombia?
Pasos para resolver un Problema:
Ejercicio introductorio
olució
1. Las grandes ciudades son urbes superpobladas con una enorme diversidad de actividades comerciales y productivas, generalmente con
grandes problemas de contaminación. ¿Cuáles
son las principales causas de la contaminación
ambiental de las grandes ciudades?
6
2. ¿Cuántos jóvenes han recibido los beneficios del plan de renovación de la educación del
país Colombia?
Estrategia para resolver un problema.
1. Leer el problema en su totalidad e
identificar los datos y la pregunta.
2. Leer el problema parte por parte y
representar los datos en un diagrama.
3. Interpretar
el
diagrama
y
extraer
conclusiones.
4. Relacionar las conclusiones con la pregunta
del problema
5. Realizar los cálculos que sean requeridos
6. Verificar resultado
3. La protección de la salud de la población es
uno de los beneficios más importantes que una
comunidad puede recibir. Se precisa saber hasta
qué punto este beneficio lo están recibiendo los
habitantes de la región del Catatumbo.
Sena Producción en multimedia
Fase Análisis
La identificación de los elementos del problema
Productos intermedios
Actividades que se describen
Estados
intermedios
Acciones u operaciones
Lo que se debe respetar
Restricciones
Lo que se desea saber
Pregunta del problema
Fase Análisis
La elaboración del diagrama
La identificación de los elementos del problema
y la elaboración del diagrama también tienen
sus particulares. Una estrategia es un conjunto
ordenado de pasos que permite lograr un objetivo.
Sena Producción en multimedia
7
ob le m as
So lu ci ón de pr
Las variables y la identificación
de los datos de un problema
Los datos de un problema, cualquiera que éste
sea, se expresan en términos de variables, de los
valores de éstas o de características de los objetos o situaciones involucradas en el enunciado.
Podemos afirmar que los datos siempre provienen de variables. Vale recordar que una variable es una magnitud que puede tomar valores
cualitativos o cuantitativos.
Para distinguir estos conceptos consideremos
el siguiente ejemplo. Si hablamos del peso del
cuerpo, nos referimos a una variable; si decimos que María pesa 60 kg, nos referimos a una
característica de María; y si decimos que la variable peso puede tomar los valores desde cero
hasta infinito, estamos hablando de valores de
la variable.
Por lo que cabe mencionar que la comprensión del enunciado de un problema está íntimamente relacionada con la identificación clara y
precisa de las variables que se consideran en el
enunciado.
Concepto de variable
El concepto de variable lo hemos utilizado en
temas anteriores con otro nombre, el de aspecto.
Siempre dijimos que edad, color, tamaño, cantidad de dinero, lugar, etc., eran aspectos; ahora
estamos dándole al aspecto un nuevo nombre,
el de variable, y estamos aprendiendo algo más
sobre éstas. Una variable es una magnitud que
puede tomar valores cualitativos o cuantitativos.
1.2. Relación entre
variables y características:
Relaciones parte-todo, de
orden, con inversiones,
con inversiones de
orden y familiares.
Una relación es un nexo entre dos o más características correspondientes a la misma variable.
En el enunciado del problema se dan los valores
de las variables que correspondan y se presentan
los nexos entre éstas; del análisis de estos nexos
surge el tipo de relación, y de éste la estrategia
particular de representación que se va a utilizar
para comprender el problema, lograr la imagen
mental y, en muchos casos, obtener la solución.
Las variables, sus valores y sus relaciones conforman los datos de los problemas. Un dato puede
ser una variable, un valor de una variable o una
relación entre dos variables o entre sus valores.
8
Sena Producción en multimedia
Fase Análisis
ob le m as
So lu ci ón de pr
Problemas acerca de las
relaciones parte-todo:
Problemas acerca de las
relaciones familiares:
En este tipo de problema unimos un
conjunto de partes conocidas para formar
diferentes cantidades y generar ciertos
desequilibrios entre las partes. Son problemas
donde se relacionan partes para formar una
totalidad deseada, por eso se denominan
“problemas sobre relaciones parte-todo”.
En este tipo de ejercicios se presenta un tipo
particular de relación referido a los nexos de parentesco entre los diferentes componentes de la
familia. Los tipos de relaciones o nexos que se
presentan entre los miembros de una familia pueden ser: Relaciones padre-hijo, entre hermanos,
tío sobrino, entre primos, entre esposos y sus
familiares, suegros, yernos, cuñados, etc.
Problemas respecto a
relaciones de orden:
La estrategia a utilizar se denomina representación lineal y permite visualizar el enunciado
de los problemas y en la mayoría de los casos,
lograr la solución. La estrategia que permite representar datos correspondientes a una sola variable o aspecto se denomina representación en
una dimensión.
Problemas acerca de las relaciones
con inversiones de orden:
En este caso se requiere aplicar una estrategia
adicional, llamada postergación, que consiste en
dejar para más tarde aquellos datos que parezcan incompletos, hasta que se presente el dato
que complete la información.
Problemas acerca de las relaciones
con inversiones de orden:
Ejercicios con enunciados confusos, en este
tipo de casos es necesario prestar atención especial a la variable, a los signos de puntuación y al
uso de ciertas palabras presentes en el enunciado.
Fase Análisis
1.3. Problemas acerca de
las relaciones entre dos
variables: tablas numéricas,
lógicas y conceptuales.
En este tipo de problemas se plantean relaciones simultaneas entre dos variables y se pide una
respuesta que corresponde a una tercera variable
que resulta de las relaciones previamente mencionadas. En este tipo de problemas la estrategia
más apropiada para obtener las soluciones es la
construcción de tablas.
La estrategia particular que se utiliza en este
caso es la representación mediante tablas, que
son reticulados que tienen filas y columnas, las
cuales determinan celdas. En las filas y las columnas se representan los tipos de variables consideradas y en las celdas se insertan los números
o valores de las diferentes pares de variables.
De las tres variables que se dan, dos son cualitativas y permiten construir la tabla, y la tercera puede ser cualitativa, cuantitativa o lógica,
según el tipo de respuesta que se pide encontrar
y los datos dados en el problema. Esta tercera
variable siempre está incluida en la pregunta del
problema y se utiliza para llenar las celdas o los
cuadros de la tabla.
Sena Producción en multimedia
9
ob le m as
So lu ci ón de pr
n
la pr og ra m ac ió
In tro du cc ió n a
0 2 Introducción a la programación
El número cero (0) se asocia con el concepto
de “nada”, de nulo o de ausencia de algo.
Tres tipos de problemas se refieren a estas
relaciones entre variables: relaciones numéricas,
relaciones lógicas entre dos o más variables y
relaciones entre conceptos. El primer tipo de
problema se resuelve mediante la construcción
de tablas numéricas; el segundo tipo de problema
se apoya en las tablas lógicas y el tercer tipo se
trabaja con tablas semánticas o conceptuales. En
la primeras se registran en las celdas cantidades
o números, en las segundas, relaciones lógicas
y en las terceras, conceptos.
Las tablas son instrumentos muy útiles para
resolver problemas pues permiten organizar la
información y visualizar el problemas; además,
constituyen una especie de memoria externa
que nos ayuda a mantener el record de algunos
elementos de información que a veces deben
postergarse para relacionarse con datos que se
dan posteriormente o que se infieren durante el
proceso de resolución de problemas.
Características de los problemas
de tablas numéricas.
Este tipo de problemas se refieren a relaciones
entre dos variables (las dos cualitativas) y se
resuelve mediante la estrategia de representación
tabular llamada tabla numérica. La estrategia se
llama así porque la tercera variable siempre toma
valores numéricos y estos valores son los que
sirven para completar la tabla.
10
Sena Producción en multimedia
Los problemas acerca de las tablas numéricas
con ceros.
El número cero (0) se asocia con el concepto
de “nada”, de nulo o de ausencia de algo. Por
esa razón es muy común confundir la falta de
información acerca de algo con el hecho establecido
de que no hay información respecto a ese algo.
Problemas acerca de tablas lógicas.
En este tipo de problemas la variable trabaja
con un tipo distinto de valor y se llama variable
lógica, que sólo puede tomar como valor los
calificativos “verdadero” o “falso”, o “si” o “no”.
Por su naturaleza, una tabla lógica tiene ciertas
propiedades que resultan muy útiles al construirlas.
Una vez completada, una tabla lógica representa
lo que es cierto y lo que no es, en forma directa
y clara. En muchos casos (pero no siempre) las
posibilidades que representa son mutuamente
excluyentes.
Problemas acerca de tablas conceptuales.
Otra manera de establecer relaciones entre
variables y características es a través de nexos
entres los conceptos; en este caso se habla de
relaciones semánticas. Las relaciones de este tipo
de problema con las variables y características es
indirecta, por medio de las características esenciales
de las clases que definen los conceptos y de sus
respectivas variables.
2.1. Conceptos generales
¿Qué es un programa?
Antes de iniciar el tema, es conveniente, sobre
todo para aquellos que comienzan su instrucción
informática, hacer un breve repaso de conceptos
fundamentales que se han de tomar en cuenta
cuando se desarrollan programas que se utilizarán
en computadoras.
Conjunto de instrucciones que hacen funcionar
a la computadora.
Organización
física
de
la
computadora
Se incluye la metodología que se requiere para
diseñar algoritmos de manera sencilla y funcional.
¿Qué es una computadora?
Es un dispositivo electrónico utilizado para
procesar información y obtener resultados.
Dispositivos de Entrada/Salida
Los datos de entrada y los datos de salida pueden
ser, realmente, cualquier cosa, texto, dibujos, o
sonidos.
Los dispositivos de Entrada/Salida permiten la
comunicación entre la computadora y el usuario
para introducir datos (información) para su proceso.
Los datos se leen de los dispositivos de entrada y
se almacenan en la memoria principal, convierten
la información de entrada en señales eléctricas
que se almacenan en la memoria principal.
¿Qué es el software?
Tipos de dispositivos de entrada:
Los datos y la información se pueden introducir
en la computadora por la entrada y a continuación
se procesan para producir una salida (resultados).
Conjunto de programas escritos para una
computadora.
¿Qué es el hardware?
Componentes físicos que constituyen la computadora,
junto con los dispositivos que realizan las tareas
de entrada y salida
• Teclados.
• Lápices ópticos.
• Palancas de mando (joystick).
• Lectores de códigos de barra.
• Micrófonos.
• Mouse
• Cámaras de video, etc
Fase Análisis
Fase Análisis
Sena Producción en multimedia
11
n
la pr og ra m ac ió
In tro du cc ió n a
Los dispositivos de salida permiten
representar resultados (salida)
del proceso de los datos.
• Pantalla.
• Impresoras.
• Trazadores gráficos (plotters).
• Reconocedores de voz, etc.
Memoria principal
Conocida como RAM (Random Access Memory),
almacena información (instrucciones de un programa
y los datos con los que operan las instrucciones) de
manera transitoria, es decir, durante la ejecución
de un programa.
Unidad Central de Proceso (UPC)
Dirige y controla el proceso de información
realizado por la computadora, esta conformada por:
Unidad de control (UC).- coordina las actividades
de la computadora y determina que operaciones se
deben realizar y en que orden; así mismo controla
y sincroniza todo el proceso de la computadora.
C++
12
Sena Producción en multimedia
n
la pr og ra m ac ió
In tro du cc ió n a
Tipos de Lenguajes
Los dispositivos son
herramientas que ayudan
expresar una idea,
mensaje o concepto
Unidad aritmética Lógica (ALU).- realiza operaciones
aritméticas y lógicas, tales como sumas, restas,
multiplicaciones divisiones y comparaciones.
Los datos se pueden leer (recuperar) o escribir
(cambiar) por la upc.Memoria auxiliar (externa)
• Cuando un programa se ejecuta, se debe
situar primero en la memoria principal de
igual modo que los datos, sin embargo, la
información almacenada en la memoria
se pierde (borra) cuando se apaga la
computadora y, por otra parte, la memoria
principal es limitada en capacidad.
Por esta razón, para poder disponer de
almacenamiento permanente, tanto para
programas como para datos se necesitan
dispositivos de almacenamiento secundario,
auxiliar o masivo.
• Los dispositivos de almacenamiento
secundario o memorias auxiliares (externas
o secundarias) más comúnmente utilizadas
son CD-ROM, DVD, cintas y discos
magnéticos, USB, etc.
Fase Análisis
Para que un procesador realice un proceso
se le debe suministrar en primer lugar un
• 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 una computadora,
el algoritmo se ha de expresar en un
formato que se denomina programa.
• Un programa se escribe en un lenguaje
de programación y las operaciones que
conducen a expresar un algoritmo en forma
de programa se llama programación.
• Así pues, los lenguajes utilizados para
escribir programas de computadoras
son los lenguajes de programación y
programadores son los escritores y
diseñadores de programas.
• Los principales tipos de lenguajes
utilizados en la actualidad son:
• Lenguajes máquina.
• Lenguajes de bajo nivel (ensamblador)
• Lenguajes de alto nivel.
• programadores son los escritores y
diseñadores de programas.
• Los principales tipos de lenguajes
utilizados en la actualidad son:
• Lenguajes máquina.
• Lenguajes de bajo nivel (ensamblador)
• Lenguajes de alto nivel.
Fase Análisis
algoritmo adecuado
• programadores son los escritores y
diseñadores de programas.
• Los principales tipos de lenguajes utilizados
en la actualidad son: Lenguajes máquina,
Lenguajes de bajo nivel (ensamblador),
Lenguajes de alto nivel.
• programadores son los escritores y
diseñadores de programas.
• Los principales tipos de lenguajes utilizados
en la actualidad son: Lenguajes máquina,
Lenguajes de bajo nivel (ensamblador),
Lenguajes de alto nivel.
Lenguajes máquina
• Son aquellos que están escritos en lenguajes
directamente inteligibles por la máquina
(computadora), ya que sus instrucciones
son cadenas binarias (cadenas o series
de dígitos 0’s y 1’s) que especifican una
operación.
• Las posiciones (dirección) de memoria
implicadas en la operación se denominan
instrucciones de máquina o código máquina
(código binario).
• Las instrucciones en lenguaje máquina
dependen del hardware de la computadora y,
por lo tanto, diferirán de una computadora
a otra.
Sena Producción en multimedia
13
n
la pr og ra m ac ió
In tro du cc ió n a
Lenguajes de bajo nivel
Lenguajes de alto nivel
• Son más fáciles de utilizar que los lenguajes
máquina, pero, al igual, que ellos, dependen de
la máquina en particular.
• El lenguaje de bajo nivel por excelencia es el
ensamblador.
• Las instrucciones en lenguaje ensamblador son
instrucciones conocidas como nemotécnicos. Por
ejemplo, típicos de operaciones aritméticas: ADD,
SUB, DIV.
• Un programa escrito en lenguaje ensamblador
no puede ser ejecutado directamente por la computadora, en esto se diferencia esencialmente del
lenguaje máquina, sino que requiere una fase de
traducción al lenguaje máquina.
• El programa original escrito en lenguaje ensamblador se denomina programa fuente y el programa traducido en lenguaje máquina se conoce
como programa objeto, ya directamente inteligible por la computadora.
• El traductor de programas fuente a objeto es un
programa llamado ensamblador.
• Son los más utilizados por los programadores,
están diseñados para que las personas escriban
y entiendan los programas de un modo más fácil que los lenguajes máquina y ensambladores.
• Un programa escrito en lenguaje de alto nivel
es independiente de la máquina; esto es, las instrucciones del programa de la computadora no
dependen del diseño del hardware o de una computadora en particular.
• Los programas escritos en lenguaje de alto nivel son portables o transportables, lo que significa la posibilidad de poder ser ejecutados con
poca o ninguna modificación en diferentes tipos
de computadoras.
• Los programas fuente en lenguaje de alto nivel
tiene que ser traducidos por los programas traductores, llamados en este caso compiladores.
Tipos de lenguajes de alto nivel:
C, C++, Fortran, C#, VisualBasic, Java
Muy extendidos:
Modula-2, Prolog, LISP, Smaltalk
Sena Producción en multimedia
2.2. Algoritmos y
diagramas de flujo
Concepto de algoritmo
Los seres humanos realizamos una serie de pasos, procedimientos o acciones que nos permiten alcanzar un resultado o resolver un problema, esto se repite innumerables veces durante el
día. En realidad estamos aplicando un algoritmo
para resolver un problema.
Definición de Algoritmo.- secuencia ordenada
y cronológica de pasos que llevan a la solución
de un problema o a la ejecución de una tarea (o
actividad).
El algoritmo debe tener las siguientes
características:
•
•
•
•
•
Tener un principio
Ser simples, claros, precisos, exactos.
Tener un orden lógico.
Debe ser finito.
Tener un fin.
• El pseudocódigo describe un algoritmo utilizando
una mezcla de frases en lenguaje común, instrucciones
de programación y palabras clave que definen las
estructuras básicas.
• El objetivo del pseudocódigo es permitir que
el programador se centre en los aspectos lógicos
de la solución, evitando las reglas de sintaxis de
los lenguajes de programación.
• No siendo el pseudocódigo un lenguaje formal,
los pseudocódigos varían de un programador a
otro, es decir, no hay un pseudocódigo estándar.
Diagramas de flujo
• Un diagrama de flujo representa la esquematización
gráfica de un algoritmo.
• En realidad muestra gráficamente los pasos o
procesos a seguir para alcanzar la solución de
un problema.
Borland Delphi, C++ Builder, Power Builder
La definición de un algoritmo debe describir
tres partes:
• Su correcta construcción es sumamente importante
porque, a partir del mismo se escribe un programa
en algún lenguaje de programación.
Aunque hoy en día el mundo de Internet consume
gran cantidad de recursos en forma de lenguajes
de programación como:
HTML, XML, JavaScript, etc.
• Entrada.
• Proceso.
• Salida
• Si el diagrama de flujo está completo y correcto,
el paso del mismo a un lenguaje de programación
es relativamente simple y directo.
La serie de pasos, procedimientos o acciones que
nos permiten alcanzar un resultado o resolver un
problema a través de algoritmos, los desarrollamos
por medio de pseudocódigo.
• A continuación, presentamos los símbolos que
utilizaremos y una explicación de los mismos.
Estos satisfacen las recomendaciones de la ISO
y la ANSI.
Gran uso en el mundo profesional:
14
n
la pr og ra m ac ió
In tro du cc ió n a
Fase Análisis
Fase Análisis
Sena Producción en multimedia
15
n
la pr og ra m ac ió
In tro du cc ió n a
n
la pr og ra m ac ió
In tro du cc ió n a
Tipos de datos
Símbolo utilizado para representar una decisión múltiple. En su
interior se almacena un selector y dependiendo del valor de dicho
selector se sigue por una de las ramas o caminos alternativos.
Símbolos utilizados para expresar la dirección
del flujo del diagrama
* Los datos a procesar por una computadora pueden clasificarse en:
• Simples
• Estructurados
Símbolo utilizado para representar una decisión. En su interior
se almacena una condición y dependiendo del resultado de la
evaluación de la misma se sigue por una de las ramas o caminos alternativos: verdadero o falso.
* Los datos simples se caracterizan porque ocupan sólo una casilla de memoria,
por lo tanto una variable simple hace referencia a un único valor a la vez. dentro de este grupo de datos encontramos:
Datos simples
Enteros
Símbolo utilizado para introducir los datos de
entrada. Expresa lectura.
Símbolo utilizado para representar la impresión
de un resultado. Expresa escritura.
Son números que no contienen componentes fraccionarias y por lo tanto, no
incluyen el punto decimal, pueden estar
precedidos del signo + o --. Por ejemplo:
465
-387
9
99
-1578
125550
Reales (flotantes)
Símbolo utilizado para expresar conexión dentro de una misma página.
Símbolo utilizado para expresar conexión entre páginas diferentes.
Son números que contienen una parte fraccionaria y por lo tanto, incluyen el punto
decimal, pueden esta precedidos del signo + o --. Por ejemplo:
125.87
-124.0
158000.75
-38.5879
Carácter
Símbolo utilizado para representar un proceso.
En su interior se expresan asignaciones, operaciones aritméticas, cambios de valor de celdas
en memoria, etc.
16
Sena Producción en multimedia
Símbolo utilizado para marcar el inicio y el fin
del diagrama flujo.
Fase Análisis
Contiene un solo carácter y va encerrado entre comillas simples. Por ejemplo:
‘a’
‘H’
Fase Análisis
‘A’
‘$’
‘#’
‘7’
‘+’
•
•
•
•
•
Enteros
Reales (flotantes)
Caracteres
Cadena de caracteres
Booleanos
* Los datos estructurados se caracterizan por el hecho de que con un nombre
se hace referencia a un grupo de casillas
de memoria.
* Es decir, un dato estructurado tiene
varios componentes. Cada uno de sus
componentes puede ser a su vez un dato
simple. Dentro de este grupo de datos se
encuentran:
• Arreglos
• Cadena de caracteres
• Registros
‘h’
Sena Producción en multimedia
17
n
la pr og ra m ac ió
In tro du cc ió n a
Cadena de caracteres.
Constantes
Contiene un conjunto de caracteres alfabéticos,
numéricos, y especiales, que sirven para representar
y manejar datos como: nombres, descripciones de
artículos, direcciones, etc. Van encerrados entre
comillas dobles, por ejemplo: “abc” “Carlos
Jiménez” “83-15-24-65” “$8#2”
Son datos que no cambian durante la ejecución de
un programa. Existen tipos de constantes como
tipos de datos, por lo tanto, puede haber constantes
enteras, reales (flotantes), de carácter, de cadenas
de caracteres, booleanas, etc.
Booleanos
Toma los valores de verdadero (true) o falso (false),
no puede ser leído o escrito, sólo asignado, es
útil para plantear cierto tipo de condiciones en
el manejo de las estructuras lógicas de control.
Identificadores, constantes y
variables Identificadores.
Son nombres que se usamos para referirnos a
variables, constantes, funciones o cualquier objeto
definido por el usuario. Un identificador se forma
de acuerdo a ciertas reglas básicas:
»» El primer carácter que forma un
identificador debe ser una letra o el símbolo
de subrayado ( _ ).
»» Los demás caracteres pueden ser letras,
dígitos o símbolo de subrayado.
n
la pr og ra m ac ió
In tro du cc ió n a
Operadores Aritméticos
Operador
Aritmético
Operación
Ejemplo
Resultado
**
Potencia
3**2
9
Variables
*
Multiplicación
5.25*3
15.75
1. Es un identificador que puede cambiar
su valor durante la ejecución de un
programa.
2. Se utiliza para representar un dato tipo
entero, real (flotante), o una constante de
carácter. Por ejemplo:
/
División
17/4 4
.25
+
Suma
58+79 1
37
-
Resta 2
5.96 -11.25 1
4.71
Mod
Módulo (residuo) 2
1 mod 2 1
div
División entera 1
9/3 6
• Variable i es de tipo entero,
• variable prom es de tipo real (flotante),
• Variable opción es de tipo carácter.
Operaciones aritméticas
Para poder realizar operaciones aritméticas
necesitamos de operadores aritméticos.
Estos operadores nos permiten realizar operaciones
aritméticas entre operandos: números, constantes o
variables. El resultado de una operación aritmética
es un número.
»» La longitud del identificador depende del
lenguaje de programación a utilizar.
Al evaluar expresiones que contienen operadores aritméticos debemos respetar la jerarquía en el
orden de aplicación. Es decir, si tenemos en una expresión más de un operador, debemos aplicar
primero el operador de mayor jerarquía, resolver esa operación y así sucesivamente.
Jerarquía de los operadores aritmé cos
Operador
Jerarquía
Operación
**
(Mayor)
Potencia
*, /, mod, div
+, -
Mul plicación, división, módulo, división entera
(menor)
Suma, resta
A continuación presentamos
en una tabla los operadores
aritméticos, la operación que
puede realizar y, un ejemplo
de su uso y su resultado:
18
Sena Producción en multimedia
Fase Análisis
Fase Análisis
Sena Producción en multimedia
19
n
la pr og ra m ac ió
In tro du cc ió n a
Reglas para resolver una expresión aritmética:
1.Si una expresión contiene subexpresiones entre paréntesis, éstas se evalúan primero, respetando
claro la jerarquía de los operadores aritméticos en esta subexpresión.
Si las subexpresiones se encuentran anidadas por paréntesis, primero se evalúan las subexpresiones
que se encuentran en el último nivel de anidamiento.
2. Los operadores aritméticos se aplican teniendo en cuenta la jerarquía y de izquierda a derecha.
n
la pr og ra m ac ió
In tro du cc ió n a
Operadores relacionales
Expresiones lógicas
Son operadores que permiten comparar dos
operandos, los operandos pueden ser números,
caracteres, constantes o variables.
Las expresiones lógicas o booleanas, están constituidas por números, constantes o variables y
operadores lógicos o relacionales. El valor que
pueden tomar estas expresiones es de verdadero o falso.
Las constantes o variables, a su vez, pueden
ser de tipo entero, real (flotante), carácter o cadena de caracteres.
El resultado de una expresión con operadores
relacionales es verdadero o falso.
Se utilizan con frecuencia en las estructuras
selectivas y en las estructuras repetitivas.
Por ejemplo:
Operadores Relacionales
Dados los siguientes casos, resolver cada caso aplicando las reglas correspondientes:
1). 7 + 5 – 6 2). 9 +7 * 8 – 36 / 5 3). 7 * 5 ** 3 / 4 div 3
1
1
1
12 – 6
9 + 56 – 36 / 5
7 * 125 / 4 div 3
2
2
2
=6
9 + 56 – 7.2
875 / 4 div 3
3
3
65 – 7.2
218.75 div 3
4
4
= 57.8
= 72
4). 7 * 8 * (160 mod 3 ** 3) div 5 * 13 – 28
3640 - 28
1
7
7 * 8 * (160 mod 27) div 5 * 13 – 28
= 3612
2
7 * 8 * 25 div 5 * 13 – 28
3
56 * 25 div 5 * 13 – 28
4
1400 div 5 * 13 – 28
5
280 * 13 – 28
6
20
Sena Producción en multimedia
Operador Operación == <>
<
>
<=
>= Igual que Diferente a Menor que Mayor que Menor o igual que
Mayor o igual que
Ejemplo “lalo” == “lola”
‘x’ < > ‘y’ 14 < 25 35 > 10 5 <= 6 15 >= 7 Resultado
Falso
Verdadero
Verdadero
Verdadero
Verdadero
Verdadero
Operadores lógicos
Fase Análisis
• Son operadores que permiten formular
condiciones complejas a partir de
condiciones simples.
• Los operadores lógicos son de:
Disyunción (o)
Conjunción (y)
Negación (No)
- Relaciona dos operandos booleanos. Proporciona un valor verdadero (V), si los dos son verdaderos; en caso
contrario da un resultado falso (F).
Este operador relaciona sólo un operando booleano y da como resultado un valor opuesto al
que tenga el operando.
Fase Análisis
Relaciona dos operandos booleanos. Proporciona
un valor verdadero (V), si uno de los dos es verdadero; e caso contrario da un resultado falso (F).
Sena Producción en multimedia
21
n
la pr og ra m ac ió
In tro du cc ió n a
n
la pr og ra m ac ió
In tro du cc ió n a
Por ejemplo:
2.4. Construcción de Algoritmos
y Diagramas de flujo
Dados los siguientes casos, resolver cada caso aplicando las reglas correspondientes:
1). A = 5, B = 16
(A ** 2) > (B * 2)
1
25 > (B * 2)
2
25 > 32
3
Falso
Continuación 2)
2). X = 6, B = 7.8
(X * 5 + B ** 3 / 4) < = (X ** 3 div B)
1
(X * 5 + 474.552 / 4) < = (X ** 3 div B)
2
(30 + 474.552 / 4) < = (X ** 3 div B)
3
(30 + 118.638) < = (X ** 3 div B)
4
Continua
148.638 < = (X ** 3 div B)
5
148.638 < = (216 div B)
6
148.638 < = 27
Falso
3). ~(15 > = 7 ** 2) o (43 – 8 * 2 div 4 < > 3 * 2 div 2)
1
~(15 > = 49) o (43 – 8 * 2 div 4 < > 3 * 2 div 2)
2
3
Estructura y diseño de un algoritmo
• Existe una gran cantidad de problemas que
requieren de un análisis profundo y de un
pensamiento flexible y estructurado para la
solución.
• La idea es ofrecer un conjunto de técnicas
y herramientas metodológicas que permitan
flexibilizar y estructurar el razonamiento
utilizado en la solución de problemas, esto
provocará finalmente la construcción de
algoritmos eficientes.
• A continuación en la figura podemos
observar las etapas que debemos seguir
para la solución de un problema.
1. La secuenciación es una estructura de
control que permite a la computadora
ejecutar una acción, después otra, luego
la que sigue y así sucesivamente hasta la
última.
2. Dichas acciones pueden consistir en
operaciones
primitivas
elementales
como declaraciones de variables, leer
datos, imprimir datos o calcular alguna
expresión.
3. Es conveniente etiquetar cada acción con
números desde el uno en forma ascendente
de uno en uno, para denotar el orden
secuencial.
4. Por lo tanto los elementos básicos que
integran la estructura de un algoritmo
son:
Continua
Continua 3).
22
~ Falso o (43 – 16 div 4 < > 3 * 2 div 2)
4
~ Falso o (43 – 4 < > 3 * 2 div 2)
5
~ Falso o (43 – 4 < > 6 div 2)
6
~ Falso o (43 – 4 < > 3)
7
~ Falso o (39 < > 3)
8
~ Falso o Verdadero
9
Sena Producción en multimedia
Verdadero o Verdadero
10
Verdadero
Fase Análisis
Fase Análisis
Nota.- Por verificación del algoritmo entendemos el
seguimiento del mismo con datos que sean representativos del problema que queremos resolver.
a. Encabezado: Todo algoritmo debe tener un encabezado
como identificación, el cual debe empezar con la palabra
Algoritmo seguida por una descripción del problema a
resolver.
b. Inicio: Todo algoritmo debe empezar con la etiqueta 1, que
marca el inicio del mismo.
c. Declaraciones: Después de marcar el inicio se debe hacer las
declaraciones que se necesiten como Variables, constantes,
tipos de datos, etc.
d. Leer, calcular e imprimir: Los siguientes pasos pueden
consistir en acciones tales como: leer datos, calcular algunas
expresiones aritméticas e imprimir datos tantas veces
como se requiera y en el orden apropiado para resolver el
problema en cuestión.
e. 5in del algoritmo: El último paso del algoritmo consiste en
incluir la indicación fin.
Sena Producción en multimedia
23
n
la pr og ra m ac ió
In tro du cc ió n a
Reglas para la construcción
de diagramas de flujo
Ejemplo No 1.- De algoritmos secuenciales
Ejemplo No 3
Calcular e imprimir el sueldo de un empleado,
se pedirá la clave del empleado, las horas trabajadas y el pago por hora trabajada.
Desarrollar un algoritmo para calcular el promedio
de un estudiante, se pedirá la matricula del estudiante y cuatro calificaciones de los exámenes. Se
imprimirá la matricula del estudiante y el promedio.
Algoritmo Calcular el sueldo de un empleado
1. Inicio
5. Imprimir cve, sueldo
2. Declaración de variables:
6. Fin
cve, ht: entero
pht, sueldo: real (flotante)
3. Leer cve, ht, pht
4. sueldo = ht * pht
n
la pr og ra m ac ió
In tro du cc ió n a
Algoritmo calcular promedio de un estudiante
1. Inicio
2. Declaración de variables
matest: entero
cal1, cal2, cal3, cal4, calfin: real (flotante)
3. Leer matest, cal1, cal2, cal3, cal4
4. calfin = (cal1 + cal2 + cal3 + cal4) / 4
5. Imprimir matest, calfin
6. Fin
Ejemplo No 2
• Debemos recordar que un diagrama de
flujo debe ilustrar gráficamente los pasos o
procesos a seguir para alcanzar la solución
de un problema.
• Los símbolos colocados adecuadamente,
permiten crear una estructura gráfica
flexible que ilustra los pasos a seguir para
alcanzar un resultado específico.
• El diagrama de flujo facilitará más tarde la
escritura del programa en algún lenguaje de
programación.
Diagrama de flujo del algoritmo, ejemplo 1
Desarrollar un algoritmo que permita leer un número en radianes
e imprima su equivalencia en grados; así mismo, leer un número
en grados e imprima su equivalencia en radianes.
Algoritmo Convierte radianes a grados y grados a radianes
1. Inicio
2. Declaración de variables:
PI = 3.145926536: real (flotante)
rad, grad, numrad, numgrad: real (flotante)
3. Leer rad, grad
4. numgrad = rad * (180 / PI)
5. numrad = grad * (PI / 180)
6. Imprimir numgrad, numrad
7. Fin
24
Sena Producción en multimedia
Fase Análisis
Fase Análisis
Reglas
• Todo diagrama de flujo debe tener un inicio
y un fin.
• Las líneas utilizadas para indicar la
dirección del flujo del diagrama deben ser
rectas, verticales y horizontales.
• Todas las líneas utilizadas para indicar la
dirección del flujo del diagrama deben
estar conectadas. La conexión puede ser a
un símbolo que exprese lectura, proceso,
decisión, impresión, conexión o fin de
diagrama.
• El diagrama de flujo debe ser construido
de arriba hacia abajo (top-down) y de
izquierda a derecha (right to left).
• La notación utilizada en el diagrama de
flujo debe ser independiente del lenguaje
de programación.
• Es conveniente cuando realizamos una tarea
compleja poner comentarios que expresen
o ayuden a entender lo que hicimos.
• Si el diagrama de flujo requiere más de una
hoja para su construcción, debemos utilizar
los conectores adecuados y enumerar las
páginas convenientemente.
• No puede llegar más de una línea a un
símbolo.
Sena Producción en multimedia
25
n
la pr og ra m ac ió
In tro du cc ió n a
le ct iv as
Es tru ct ur as se
03
Diagrama de flujo del algoritmo, ejemplo 2
Estructuras Selectivas
3.1. Si Entonces (If Then)
Selección si-entonces
Funcionamiento:
• La estructura selectiva lógica “si entonces”
permite que el flujo siga por un camino
específico si se cumple una condición o un
conjunto de condiciones.
• Si al evaluar la condición (o condiciones) el
resultado es verdadero, entonces se ejecuta
(n) cierta (s) operación (es), luego continua
con la secuencia normal del proceso.
• Se utiliza cuando alguna operación está
condicionada para que se lleve a cabo, pero
no tiene una opción alterna.
Al llegar al si se evalúa la condición (es):
a. Si se cumple, se ejecuta (n) la (s) operación
(es) del entonces y luego salta hasta
el siguiente paso después del fin del
condicional.
b. Si no se cumple, salta hasta después del fin
del condicional, es decir no hace nada.
Diagrama de flujo del algoritmo, ejemplo 3
Diagrama de flujo
Formato:
si condición entonces
operación (es)
{ Fin del condicional }
Donde:
• si.- identifica la estructura selectiva
• condición.- expresa la condición o
conjunto de condiciones a evaluar
• entonces.- indica el curso de acción a
seguir si se cumple la condición.
• operación.- expresa la operación o
conjunto de operaciones.
• fin del condicional.- indica el fin de la
estructura de selección (si)
26
Sena Producción en multimedia
Fase Análisis
Fase Análisis
Sena Producción en multimedia
27
le ct iv as
Es tru ct ur as se
Ejemplo 1: Dado como dato una calificación
de un alumno en un examen, desarrollar un algoritmo y diagrama de flujo, que imprima el mensaje de aprobado en caso de que la calificación
sea mayor o igual a 70.
3.2. Si Entonces Sino
(If Then Else)
Diagrama de flujo
Algoritmo Alumno aprobado
1. Inicio
2. Declaración de variables
cal: flotante
3. Leer cal
4. si cal >=70 entonces
imprimir “Aprobado”
5. Fin del condicional paso 4
6. Fin
Ejemplo 2: Dado como dato el sueldo de un
trabajador, desarrollar un algoritmo y diagrama
de flujo, que aplique un aumento del 15% si su
sueldo es inferior a $1000. se imprimirá el nuevo sueldo del trabajador.
Algoritmo Aumento de sueldo de un trabajador
1. Inicio
2. Declaración de variables:
sue, aum, nsue: flotante
3. Leer sue
4. si sue < 1000 entonces
aum = sue * 0.15
nsue = sue + aum
imprimir nsue
5. Fin del condicional paso 4
6. Fin
28
Sena Producción en multimedia
le ct iv as
Es tru ct ur as se
Selección si entonces/sino
Formato:
• La estructura selectiva si entonces/sino
permite que el flujo se bifurque por dos
ramas diferentes en el punto de la toma de
decisión (es).
• Si al evaluar la condición (o condiciones)
el resultado es verdadero, entonces sigue
por un camino específico y se ejecuta (n)
cierta (as) operación (es). Por otra parte,
si el resultado es falso entonces se sigue
por otro camino y se ejecuta (n) otra (s)
operación (es).
• En ambos casos, luego de ejecutarse la (s)
operación (es) indicada (s), se continúa con
la secuencia normal del proceso.
• Por la naturaleza de éstas, se debe ejecutar
una o la otra, pero no ambas a la vez, es
decir, son mutuamente excluyentes.
si condición
entonces
hacer operación 1
sino
hacer operación 2
{ Fin del condicional }
Donde:
• si.- identifica la estructura selectiva
• condición.- expresa la condición o
•
•
•
•
Diagrama de flujo
conjunto de condiciones a evaluar
entonces.- indica el curso de acción a
seguir si se cumple la condición.
operación 1.- expresa la operación o
conjunto de operaciones.
operación 2.- expresa la operación o
conjunto de operaciones.
fin del condicional.- indica el fin de la
estructura de selección (si)
Funcionamiento:
Al llegar al si se evalúa la condición (es):
• Opción verdadera (entonces) si se cumple, se ejecuta (n)
la (s) operación (es) del entonces y luego salta hasta el
siguiente paso después del fin del condicional.
• Opción falsa (sino) De lo contrario, salta hacia el sino, ejecuta
la (s) operación (es), y después salta hasta el siguiente paso
después del fin del condicional.
Fase Análisis
Fase Análisis
Sena Producción en multimedia
29
le ct iv as
Es tru ct ur as se
le ct iv as
Es tru ct ur as se
Diagrama de flujo
Diagrama de flujo
• Encontramos numerosos casos en el
desarrollo de la solución de problemas en el
que luego de tomar una decisión y marcar
el camino correspondiente a seguir, es
necesario tomar otra decisión.. Se señala,
luego de evaluar las condiciones , la rama
correspondiente a seguir, y nuevamente
podemos tener que tomar otra decisión.
• El proceso puede repetirse numerosas
veces. En este caso, para resolver el
problema, estamos aplicando estructuras
selectivas en cascada o anidadas.
• A continuación presentamos diferentes
casos de anidamiento para la estructura
selectiva si:
Diagrama de flujo
Ejemplo 1: Dado como dato una calificación
de un alumno en un examen, desarrollar un algoritmo y diagrama de flujo, que imprima el mensaje de aprobado en caso de que la calificación sea
mayor o igual a 70 o reprobado en caso contrario.
Algoritmo
1. Inicio
2. Declaración de variables
cal: flotante
3. Leer cal
4. si cal >=70 entonces
imprimir “Aprobado”
sino
imprimir “Reprobado”
4. Fin del condicional paso 4
5. Fin
30
Sena Producción en multimedia
Estructuras selectivas anidadas:
nsi condición1 entonces
n1
si condición2
entonces
hacer operación21
sino
hacer operación22
n2 fin del condicional del paso n1
n + 1 fin del condicional del paso n
Ejemplo 2: Dado como dato el sueldo de un
trabajador, desarrollar un algoritmo y diagrama
de flujo, que aplique un aumento del 15% si su
sueldo es inferior a $1000 y 12% en caso contrario. Se imprimirá el nuevo sueldo del trabajador.
Algoritmo
1. Inicio
2. Declaración de variables:
sue, nsue: flotante
3. Leer sue
4. si sue < 1000 entonces
nsue = sue * 1.15
sino
nsue = sue *1,12
5. Fin del condicional paso 4
6. Imprimir nsue
7. fin
Caso 1
Caso 2
Fase Análisis
Fase Análisis
Sena Producción en multimedia
31
le ct iv as
Es tru ct ur as se
Lenguaje algorítmico de la estructura selectiva
anidada del diagrama de flujo caso2:
Lenguaje algorítmico de la estructura selectiva
anidada del diagrama de flujo caso3:
n si condición1
entonces
n1 si condición2
entonces
hacer operación 21
sino
hacer operación 22
n2 fin del condicional del paso n1
sino
n3 si condición3 entonces
hacer operación 31
n4 fin del condicional del paso n3
n +1 fin del condicional del paso n
n si condición1
entonces
n1 si condición2 entonces
hacer operación 21
n2 fin del condicional paso n1
sino
n3 si condición3
entonces
hacer operación 31
sino
hacer operación 32
n4 fin del condicional del paso n3
n +1 fin del condicional del paso n
le ct iv as
Es tru ct ur as se
Ejemplo 1: Desarrollar un algoritmo y diagrama de flujo el cual, dado un valor entero, determinar si es cero, positivo o negativo.
Diagrama de flujo
Algoritmo Dado un valor entero determinar si es
cero, positivo o negativo
1 inicio
2 Declaración de variables:
num: entero
3 Leer num
4. si num ==0
entonces
imprimir “cero”
sino
4.1 si num > 0
entonces
imprimir “positivo”
sino
imprimir “negativo”
4.2 fin del condicional paso 4.1
5 fin del condicional del paso 4
Diagrama de flujo
32
Sena Producción en multimedia
Fase Análisis
Fase Análisis
Sena Producción en multimedia
33
le ct iv as
Es tru ct ur as se
le ct iv as
Es tru ct ur as se
Diagrama de flujo
3.4. Si Multiple (Case)
Estructura selectiva si múltiple
• La estructura selectiva si múltiple permite
que el flujo del proceso se bifurque por
varias ramas en el punto de la toma de
decisión (es), esto en función del valor que
tome el selector.
• Si el selector toma el valor 1 se ejecutará
la acción 1, si toma el valor 2 se ejecutará
la acción 2, si toma el valor n se realizará
la acción n, y si toma un valor distinto de
los valores comprendidos entre 1 y n, se
continuará con el flujo normal del proceso
realizándose la acción n + 1.
Diagrama de flujo
Formato:
Por ejemplo: Desarrollar un algoritmo y diagra-
si selector igual
valor 1: hacer acción 1
valor 2: hacer acción 2
valor 3: hacer acción 3
valor n: hacer acción n
fin del condicional
hacer acción n + 1
ma de flujo tal que dado como datos la categoría
y el sueldo de un trabajador, calcule el aumento
correspondiente teniendo en cuenta la siguiente
tabla. Se imprimirá la categoría del trabajador y
su nuevo sueldo.
Categoria
1
2
3
4
Donde:
Selector.- variable o expresión a evaluarse, según la cual se tomará una de las múltiples
decisiones o alternativas.
Acción 1.- expresa la operación o conjunto
de operaciones que se van a realizar si el selector toma el valor 1.
Acción 2.- expresa la operación o conjunto
de operaciones que se van a realizar si el selector toma el valor 2.
Acción n.- expresa la operación o conjunto
de operaciones que se van a realizar si el selector toma el valor n.
Acción n + 1.- expresa la operación que
se va a realizar cuando se continúe con el flujo
normal del proceso.
La estructura selectiva si múltiple es muy flexible, lo que permite aplicarse de diferentes formas.
Por ejemplo observemos el siguiente formato:
Aumento
15%
10%
8%
7%
Algoritmo:
1. Inicio Dado la categoría y el sueldo de un trabajador calcular el aumento
2. Declaración de variables:
cate: entero
sue, nsue: flotante
3. Leer cate, sue
Diagrama de flujo
4. si cate igual
1: nsue = sue * 1015
2: nsue = sue * 1010
3: nsue = sue * 1.08
4: nsue = sue * 1.07
5. Fin de la condición del paso 2
6. imprimir cate, sue
7. Fin
si selector igual
valor 1,2: hacer acción 1
valor 3,4,5: hacer acción 2
de otra forma : hacer acción 3
fin del condicional
hacer acción x
34
Sena Producción en multimedia
Fase Análisis
Fase Análisis
Sena Producción en multimedia
35
pe tit iv as
Es tru ct ur as re
04
pe tit iv as
Es tru ct ur as re
Estructuras Repetitivas
Diagrama de flujo
4.1. Mientras que (While)
Estructura repetitiva mientras (while)
Formato:
• La
estructura
algorítmica
mientras
comúnmente conocida como while, es la
estructura adecuada para utilizar en un
ciclo cuando no sabemos el número de
veces que éste se ha de repetir.
• Dicho número depende de las proposiciones
dentro del ciclo.
• Esta estructura permite que se repita una
acción o un conjunto de acciones, en tanto
cierta condición se mantenga verdadera.
• La estructura while evalúa primero la
condición, si se cumple se ejecuta una
acción o conjunto de acciones; si no se
cumple, no entra al ciclo. Por lo tanto esta
estructura se repite cero o más veces.
Hacer PI = proposición inicial
Mientras PI es verdadera repetir
•
•
•
proceso
•
•
•
Hacer PI = modificación de PI
{ Fin del ciclo }
Donde:
PI.- proposición inicial, si el valor de PI
es falso, entonces el ciclo no se ejecuta.
Ejemplo2: Desarrollar un algoritmo y diagrama
de flujo para obtener la suma de los gastos que
hicimos en nuestro último viaje, pero no sabemos exactamente cuántos fueron, deberá mostrar
la suma total de los gastos.
Diagrama de flujo
Diagrama de flujo
36
Sena Producción en multimedia
Ejemplo1: Desarrollar un algoritmo y diagrama de flujo que lea
n números positivos, determine y muestre el promedio de los n números positivos.
Algoritmo: Dado n números positivos obtenga el promedio
1. inicio
6. prom = suma / n
2. declaración de variables:
7. imprimir prom
i, n: enteros
8. fin
num, prom, suma =0: flotantes
2. leer n
3. i = 1
4. mientras i <= n
leer num
suma = suma + num
i = i + 1
5. fin del ciclo del paso 4
Fase Análisis
Algoritmo: Obtener la suma de los gastos del viaje
1. inicio
2. declaración de variables:
gasto, sumgas = 0: flotante
3. leer gasto
4. mientras gasto < > -1 repetir
sumgas = sumgas + gasto
leer gasto
5. fin del ciclo del paso 4
6. imprimir sumgas
7. fin
Fase Análisis
Sena Producción en multimedia
37
pe tit iv as
Es tru ct ur as re
pe tit iv as
Es tru ct ur as re
Formato:
4.2. Repetir para (For)
Estructura repetitiva repetir (for)
• La estructura repetir conocida comúnmente
como for, es la estructura algorítmica
adecuada para realizar un ciclo que se
ejecutará un número definido de veces.
• Este tipo de estructura está presente en
todos los lenguajes de programación, ya
sean estructurados u orientados a objetos.
Por ejemplo cuando necesitamos calcular la
nómina total de la empresa, tenemos que
sumar los sueldos de los n empleados de la
misma.
• Cuando necesitamos obtener el promedio
de calificaciones de un curso, debemos
sumar las n calificaciones de los alumnos y
dividir esa suma entre n. Es decir, sabemos
de antemano cuántas veces tenemos que
repetir una determinada operación, acción
o tarea.
• El número de repeticiones no depende de las
proposiciones dentro del ciclo, el número
de veces se obtiene del planteamiento del
problema o de una lectura que indica que el
número de iteraciones se debe realizar para
n ocurrencias.
• Dicho de otra forma el ciclo, es controlado
por un contador que tiene que definirse
con un valor inicial, un valor final y
un incremento, esto significa que debe
conocerse de antemano el número de veces
que se debe repetir el ciclo.
38
Sena Producción en multimedia
Fase Análisis
a) Forma ascendente
b) Forma descendente
hacer V = VI
hacer V = VI
repetir con V desde VI hasta VFrepetir con V desde VI hasta VF
•
•
•
•
procesoproceso
•
•
•
•
hacer V = V + ID
hacer V = V – ID
{ Fin del ciclo }
{ Fin del ciclo }
Donde:
Funcionamiento:
V.- variable de control del ciclo.
VI.- valor inicial.
VF.- valor final.
ID.- incremento o decremento, según sea
la estructura ascendente o descendente.
V (contador del ciclo, generalmente representado por las variables i, j, k) toma un valor inicial y se compara con VF (valor final). El ciclo
se ejecuta mientras V es menor, menor o igual,
mayor, mayor o igual al valor de VF, el valor de
V se incrementa o decrementa en cada iteración.
Cuando V supera el valor de VF entonces el ciclo se detiene.
Fase Análisis
Sena Producción en multimedia
39
pe tit iv as
Es tru ct ur as re
pe tit iv as
Es tru ct ur as re
Ejemplo 1: Desarrollar un algoritmo y diagrama de flu-
Diagrama de flujo
jo tal que dado como datos 10 números enteros, obtenga la
suma de los 10 números enteros. Se mostrará la suma de
los 10 números enteros.
1. inicio Dado 10 números enteros obtener la suma
2. declaración de variables:
i, num, suma = 0: entero
3. i = 1
4. repetir con i desde 1 hasta 10
leer num
suma = suma + num
i = i + 1
5. fin del ciclo del paso 3
6. imprimir suma
7. fin
4.3. Hacer mientras (Do … while)
Diagrama de flujo
Ejemplo 2: Desarrollar un algoritmo y diagrama de flujo tal que dado como datos n números
enteros, obtenga la suma de los n números enteros. Se mostrará la suma de los n números enteros.
1. inicio Dado n números enteros obtener
la suma
2. declaración de variables:
i, num, n, suma = 0: entero
3. leer n
4. i = 1
5. repetir con i desde 1 hasta n
leer num
suma = suma + num
i = i + 1
6. fin del ciclo del paso 3
7. imprimir suma
8. fin
40
Sena Producción en multimedia
Fase Análisis
Estructura repetitiva hacer
mientras (do/while)
• La estructura algorítmica hacer mientras
comúnmente conocida como do/while, es
una estructura de control que permite hacer
una repetición en un intervalo de uno a n
veces, esto se debe a que la condición de
control del ciclo se coloca al final de la
estructura y se entra al ciclo sin evaluar la
condición.
• Primero se ejecuta y luego se evalúa la
condición, si se cumple se regresa al ciclo,
si no, termina el ciclo. Por lo tanto se
ejecutará una o más veces.
Formato:
Hacer PI = proposición inicial
Hacer
•
•
•
proceso
•
•
•
Hacer PI = modificación de PI
Mientras (condición PI)
{ Fin del ciclo }
Donde:
PI.- proposición inicial, si el valor de PI es falso, entonces el ciclo no se ejecuta.
Fase Análisis
Sena Producción en multimedia
41
pe tit iv as
Es tru ct ur as re
Diagrama de flujo
pe tit iv as
Es tru ct ur as re
Ejemplo 2: Desarrollar un algoritmo y diagrama de flujo el cual, para n números enteros
positivos mostrar los pares.
Algoritmo Para n números enteros positivos mostrar los pares
Ejemplo 1: Desarrollar un algoritmo y diagrama de flujo el cual, obtenga el promedio de
n números enteros, mostrar el promedio de los
n números.
1. inicio
2. declaración de variables:
i, n: entero
3. leer n
4. i = 2
5. hacer
imprimir i
i = i + 2
mientras (i < = n)
6. fin del ciclo del paso 5
7. fin
Algoritmo Obtener el promedio de n números
enteros
Diagrama de flujo
Diagrama de flujo
1. inicio
2. declaración de variables:
i, n: enteros
num, suma = 0, prom: flotantes
3. leer n
4. i = 1
5. hacer
leer num
suma = suma + num
i = i + 1 mientras (i < = n)
6. fin del ciclo del paso 5
7. prom = suma / n
8. imprimir prom
9. fin
42
Sena Producción en multimedia
Fase Análisis
Fase Análisis
Sena Producción en multimedia
43
)
Da to s (A rre gl os
Es tru ct ur as de
05
)
Da to s (A rre gl os
Es tru ct ur as de
Estructuras de Datos (Arreglos)
●●●
5.1 Arreglos en una
dimensión o Vectores
44
Arreglos
Definición de arreglo
• El arreglo es un tipo de dato estructurado
formado por un conjunto de elementos de
un mismo tipo de datos.
• En las unidades anteriores trabajamos
con tipos de datos enteros, flotantes,
cadenas, etc., los cuales son considerados
como datos de tipo simple, puesto que
una variable que se define con alguno de
estos tipos sólo puede almacenar un valor
a la vez, es decir, existe una relación de
uno a uno entre la variable y el número
de elementos (valores) que es capaz de
almacenar.
• En cambio un dato de tipo estructurado
como el arreglo, puede almacenar a más
de un elemento (valor) a la vez, con la
condición de que todos los elementos deben
ser del mismo tipo de dato, es decir, que
se puede tener un arreglo de datos enteros,
flotantes, etc.
• Los arreglos se clasifican de acuerdo con
el número de dimensiones que tienen. Así,
se tienen los arreglos unidimensionales
(una dimensión), los bidimensionales (dos
dimensiones) y los multidimensionales ( de
más de dos dimensiones ), etc.
Un arreglo se define como una colección finita,
homogénea y ordenada de elementos:
Sena Producción en multimedia
Finita.- todo arreglo tiene un límite, es decir se
sabe determinar cuál será el número máximo de
elementos que podrán formar parte del arreglo.
Homogénea.- todos los elementos de un arreglo son del mismo tipo.
Ordenada.- se puede determinar cuál será el
primer elemento, el segundo, el tercero, … , y
el n-ésimo elemento.
Un arreglo puede
representarse gráficamente
como se muestra a
continuación:
Fase Análisis
Arreglos unidimensionales
• Un arreglo unidimensional, está formado
por un conjunto de elementos de un mismo
tipo de datos que se almacenan bajo un
mismo nombre y se diferencian por la
posición (índice) que tiene cada elemento
dentro del arreglo de datos. Por ejemplo:
tenemos el número de unidades producidas
por un obrero en cada uno de los días
del mes. Para almacenarlos y manejarlos
definimos un arreglo de una dimensión
de 30 elementos, como se muestra a
continuación:
• El cual define un arreglo llamado
producción con 30 casillas o lugares para
almacenar los datos de 30 días.
Fase Análisis
Producción
1
2
3
*
*
*
30
Sena Producción en multimedia
45
)
Da to s (A rre gl os
Es tru ct ur as de
Declaración de arreglo unidimensional
Manejo de los elementos de un arreglo
Lectura
Escritura
Cuando se declara un arreglo, es necesario hacerlo como una variable:
Cada elemento individual de un arreglo se relaciona con el nombre de la variable y un número
(índice) que indica la posición la posición que
ocupa el elemento dentro del arreglo. Dicho número se pone entre [ ] y se le llama subíndice.
De acuerdo con el ejemplo anterior:
El proceso de lectura de un arreglo consiste en
leer y asignar un valor a cada uno de sus elementos. Consideremos de nuevo nuestro ejemplo una
forma podría ser de la siguiente manera:
El caso de escritura es similar al de lectura. Se
debe escribir el valor de cada uno de los componentes, por ejemplo, considerando nuestro ejemplo:
Nombre Variable: Arreglo [tamaño] Tipo de dato
Donde:
Nombre Variable.- Nombre de identificación
de la variable.
Arreglo.- Palabra reservada que indica que la
variable es un arreglo.
Tamaño.- Número entero que indica la cantidad
de elementos que tendrá el arreglo.
Tipo.- Tipo de dato que tendrá el conjunto de elementos del arreglo que se esta definiendo, puede
ser entero, real, carácter, etc.
El elemento 1 se relaciona con Producción[1]
El elemento 2 se relaciona con Producción[2]
•
•
•
El elemento 30 se relaciona con Producción[30]
• El subíndice puede ser una constante
numérica entera como 1, 2, 3,…, 30, una
variable de tipo entero, como: Producción [
i ], o bien, una expresión algebraica que de
un resultado de tipo entero como:
Si recordamos el ejemplo anterior, la forma de
declararlo es:
Producción: Arreglo [30] entero
46
)
Da to s (A rre gl os
Es tru ct ur as de
Producción es el nombre de la variable.
Es un arreglo que contiene 30 elementos
(de 1 a 30).
Cada elemento del arreglo será un dato de
tipo entero.
Sena Producción en multimedia
Producción [ i + 3 ]
Producción [ (i * 4) – j ]
Leer
Leer
•
Leer
Producción[1],
Produccion[2],
•
•
Producción[30]
De esta forma no resultaría práctico, por lo tanto se usará un ciclo para leer todos los elementos del arreglo:
i=1
repetir con i desde 1 hasta 30
leer Producción[i]
i=i+1
fin del ciclo
• Como toda variable, una de tipo arreglo
puede usarse para leer datos, asignarle
valores mediante expresiones aritméticas,
imprimir su contenido, formar parte de
expresiones lógicas , etc.
Fase Análisis
Fase Análisis
i=1
repetir con i desde 1 hasta 30
imprimir Producción[i]
i = i + 1
fin del ciclo
Ejemplo1: Desarrollar un algoritmo y diagrama
de flujo que reciba como entrada un arreglo unidimensional de n valores de tipo entero y muestre el arreglo unidimensional:
• Algoritmo Arreglo de n elementos enteros
mostrarlos
1. inicio
2. declaración de variables:
i, n: entero
arr: arreglo[n] entero
3. leer n
4. i = 1
5. repetir con i desde 1 hasta n
leer arr[i]
i = i +1
6. fin del ciclo del paso 5
7. i = 1
8. repetir con i desde 1 hasta n
imprimir arr[i]
i = i + 1
9. fin del ciclo del paso 8
10. fin
Sena Producción en multimedia
47
)
Da to s (A rre gl os
Es tru ct ur as de
)
Da to s (A rre gl os
Es tru ct ur as de
Diagrama de flujo
48
Diagrama de flujo
Ejemplo 2: Desarrollar un algoritmo y diagra-
Algoritmo
ma de flujo que reciba como entrada un arreglo
unidimensional que corresponde a los sueldos
de un grupo de 70 empleados de una empresa y
necesitamos saber cuántos de estos empleados
tienen un sueldo superior al promedio del grupo. Mostrar el total de empleados que tiene un
sueldo superior al promedio del grupo.
1. inicio
2. declaración de variables:
i, conta = 0: entero
prom, acsue = 0: flotante
sue: Arreglo[70] flotante
3. i = 1
4. repetir con i desde 1 hasta 70
leer sue[i]
acsue = acsue + sue[i]
i = i + 1
5. fin del ciclo del paso 4
6. prom = acsue / 70
7. i = 1
8. repetir con i desde 1 hasta 70
8.1 si sue[i] > prom entonces
conta = conta + 1
8.2 fin del condicional del paso 8.1
i = i + 1
9. fin del ciclo del paso 8
10. imprimir conta
11. fin
Sena Producción en multimedia
Fase Análisis
Ejemplo 3: Desarrolla un algoritmo y diagra-
Algoritmo
ma de flujo que reciba como entrada dos arreglos
unidimensionales cada uno con 20 números enteros, calcular la suma uno a uno de los elementos
de los dos arreglos y almacenar el resultado en un
tercer arreglo. Mostrar al final los tres arreglos.
1. inicio
2. declaración de variables:
a, b, c: Arreglo[20] entero
i: entero
3. i = 1
4. repetir con i desde 1 hasta 20
leer a[i]
leer b[i]
c[i] = a[i] + b[i]
i = i + 1
5. fin del ciclo del paso 4
6. i = 1
7. repetir con i desde 1 hasta 20
imprimir a[i], b[i], c[i]
i = i +1
8. fin del ciclo del paso 7
9. fin
Fase Análisis
Sena Producción en multimedia
49
)
Da to s (A rre gl os
Es tru ct ur as de
Diagrama de flujo
)
Da to s (A rre gl os
Es tru ct ur as de
Representación de un
arreglo bidimensional:
Tal que:
1<=i<=M
1<=j<=N
1
2
.
j
.
N
1
2
.
i
.
M
Arreglos multidimensionales
• Los arreglos presentados en el tema
anterior reciben el nombre de arreglos
unidimensionales o lineales, debido a que
cualquier elemento es referenciado por un
único índice.
• También existe en la mayoría de los
lenguajes de programación una estructura
de arreglos multidimensionales. El número
de dimensiones (índices) que se deben
utilizar en un arreglo depende del problema
que debemos resolver.
• En este tema analizaremos los arreglos
bidimensionales (caso especial de los
multidimensionales) por ser los mas
utilizados.
50
Sena Producción en multimedia
• El arreglo bidimensional o de dos
dimensiones, está formado por un conjunto
de elementos de un mismo tipo de datos
que se almacenan bajo un mismo nombre
y que al igual que en el unidimensional,
se diferencian por la posición que tiene
cada elemento dentro del arreglo de datos,
con la aclaración de que la disposición de
los elementos es en forma rectangular o
cuadrada, donde la primera dimensión está
dada por los renglones y la segunda por las
columnas.
• Un arreglo de este tipo, también conocido
como matriz, es del orden
M x N, donde
M es el número de renglones y N el número
de columnas, es decir, en forma de tabla.
• Un elemento [i, j] estará en el renglón i y
en la columna j. internamente en memoria
se reservan M x N posiciones consecutivas
para almacenar todos los elementos del
arreglo.
Fase Análisis
Declaración de arreglos
bidimensionales
Donde:
Al declarar un arreglo es necesario hacerlo como
una variable, por la cual en la parte de declaraciones de variables se utiliza el siguiente formato:
de la variable.
Arreglo.- palabra reservada que indica que la
variable es un arreglo.
TamañoRenglones.- indica el número de renglones que tendrá el arreglo.
TamañoColumnas.- indica el número de columnas que tendrá el arreglo
Tipo de dato.- es el tipo de dato que tiene el
conjunto de elementos del arreglo que se está
definiendo; puede ser entero, real, etc.
NombreArreglo: Arreglo[TamañoRenglones,
TamañoColumnas] Tipo de dato.
NombreArreglo.- nombre de identificación
Por ejemplo, si aplicamos los conceptos del formato para definir la matriz de orden 4 x 5 de números enteros, tenemos:
Matriz: Arreglo[4, 5] entero
1. Matriz es el nombre de la variable.
2. Es un arreglo que contiene a renglones y 5 columnas (20 elementos).
3. Cada elemento del arreglo es un dato de tipo
entero.
Fase Análisis
Sena Producción en multimedia
51
)
Da to s (A rre gl os
Es tru ct ur as de
)
Da to s (A rre gl os
Es tru ct ur as de
Manejo de los elementos de una matriz
Lectura
Escritura
Para relacionar cada elemento individual de una
matriz se usan dos subíndices; el primero indica
el renglón y el segundo la columna, como sigue:
Matriz[Renglón, Columna]
Para realizar la lectura de una matriz los elementos deben referenciarse por medio de dos índices,
normalmente se usan dos ciclos (anidados) para
lograr la lectura de elementos consecutivos. Por
ejemplo leer los elementos de una matriz de orden 5 x 3, los pasos a seguir son los siguientes:
El procedimiento para una escritura es similar
al de una lectura
donde:
Renglón.- indica el número de renglón y
Columna.- indica el número de columna que
ocupa el elemento relacionado.
Los subíndices pueden ser constantes, variables
o expresiones de tipo entero.
Como toda variable, una de tipo matriz puede
usarse para leer datos, asignarle valores mediante expresiones aritméticas, imprimir su contenido, formar parte de expresiones lógicas, etc.
Por ejemplo:
Matriz[1, 1] = 20
Leer Matriz[R, C]
Leer Matriz[3, 4]
Matriz[1, 2] = Matriz[1, 2] + Matriz[2, 3]
Imprimir Matriz[1, 2]
i=1
Repetir con i desde i hasta 5
j = 1
Repetir con j desde 1 hasta 3
leer matriz[i, j]
j=j+1
fin del ciclo interno
i = i + 1
fin del ciclo externo
i=1
Repetir con i desde 1 hasta 5
j = 1
Repetir con j desde 1 hasta 3
Imprimir Matriz[i, j]
j = j +1
fin del ciclo interno
i = i + 1
fin del ciclo externo
Al variar los índices de i y j se lee un elemento de matriz, según la posición indicada por los
índices i y j
Para i = 1 y j = 1, se lee el elemento del renglón
1 y columna 1
i = 1 y j = 2, se lee el elemento del renglón 1 y
columna 2
•
•
•
•
i = 5 y j =3, se lee el elemento del renglón 5 y
columna 3
52
Sena Producción en multimedia
Fase Análisis
Fase Análisis
Ejemplo 1: Desarrollar un algoritmo y diagrama de flujo el cual, reciba como entrada un arreglo bidimensional de orden m x n con valores de
tipo entero y muestre el arreglo bidimensional:
Algoritmo
1. inicio
2. declaración de variables:
i, j, m, n: entero
mat: Arreglo[m, n] entero
3. leer m, n
4. i = 1
5. repetir con i desde 1 hasta m
j = 1
5.1 repetir con j desde 1 hasta n
leer mat[i, j]
j=j+1
5.2 fin del ciclo del paso 5.1
i = i + 1
6. fin del ciclo del paso 5
7. i = 1
8. repetir con i desde 1 hasta m
j = 1
8.1 repetir con j desde 1 hasta n
imprimir mat[i, j]
j=j+1
8.2 fin del ciclo del paso 8.1
i = i + 1
9. fin del ciclo del paso 8
10. fin
Sena Producción en multimedia
53
)
Da to s (A rre gl os
Es tru ct ur as de
Diagrama de flujo
)
Da to s (A rre gl os
Es tru ct ur as de
Ejemplo 2: Desarrollar un algoritmo y dia-
Algoritmo
grama de flujo el cual reciba como entrada un
arreglo bidimensional de orden m x n con valores de tipo entero, para calcular la suma de los
elementos de la diagonal principal. Mostrará el
arreglo bidimensional y la suma de los elementos de la diagonal principal.
1. inicio
2. Declaración de variables
i, j, m, n, sumdiag=o: entero
mat: Arreglo[m, n] entero
3. Leer m, n
4. i = 1
5. repetir con i desde 1 hasta m
j=1
5.1 repetir con j desde 1 hasta n
leer mat[i, j]
5.1.1 si i == j entonces
sumdiag = sumdiag + mat[i, j]
5.1.2 fin del condicional 5.1.1
j=j+1
5.2 fin del ciclo del paso 5.1
i=i+1
6. fin del ciclo del paso 5
7. i = 1
8. repetir con i desde 1 hasta m
j = 1
8.1 repetir con j desde 1 hasta n
imprimir mat[i, j]
j=j+1
8.2 fin del ciclo del paso 8.1
i = i + 1
9. fin del ciclo del paso 8
10. imprimir sumdiag
11. fin
Continuación del Diagrama de flujo
54
Sena Producción en multimedia
Fase Análisis
Fase Análisis
Sena Producción en multimedia
55
)
Da to s (A rre gl os
Es tru ct ur as de
He rra m ie nt as
ió n
pa ra la si m ul ac
06
Diagrama de flujo
Herramientas para la simulación
6.1. Pseudocódigo LPP
Lpp es un lenguaje de programación para principiantes, el cual fue diseñado con la idea de facilitar el proceso de enseñanza-aprendizaje de un
leguaje de programación en nuestro idioma, este
contiene la mayoría de instrucciones que tienen
los lenguajes de programación.
Va dirigido a todos aquellos que quieren empezar en el gran mundo de la programación y no
saben por dónde empezar. Es una forma fácil de
aprender ya que se trata de una forma de programación en nuestro propio lenguaje.
Continuación del Diagrama de flujo
56
Sena Producción en multimedia
Fase Análisis
Fase Análisis
Sena Producción en multimedia
57
He rra m ie nt as
ió n
pa ra la si m ul ac
6.2. Diagramas de flujo DFD
DFD es un editor e intérprete de diagramas de
flujo con el cual puedes dar forma gráfica a un
gran número de algoritmos, ejecutarlos y depurarlos en caso de hallar errores.
Los diagramas de flujo (también llamados DFD)
sirven para representar algoritmos y procesos
similares que resuelven problemas a través del
computador. DFD nos permite enriquecer y completar esos diagramas DFD incluyendo multitud
de elementos y guardándolos después en el disco o imprimiéndolos mediante una impresora.
En la barra superior de DFD se agrupan los
objetos necesarios para la construcción de los
diagramas. Se parte siempre de una plantilla con
un estado inicial y uno final, conectados por una
flecha. Los ítems se posicionan con un clic sobre
el tramo de conexión elegido: DFD se encarga
de redibujar los elementos.
Glosario
Dependiendo del tipo de objeto, hacer dobleclic abrirá un cuadro de diálogo diferente en el
que introducir datos. Por ejemplo, en Condición
se puede establecer la dirección de la condición
verdadera y la expresión que debe verificarse.
DFD simplifica bastante el diseño de los subprogramas.
Cuando quieras probar tu diagrama, la tecla
F9 iniciará la ejecución. También puedes usar
los controles de reproducción o recurrir al menú
Depuración para evaluar una expresión o efectuar un paso simple. El directorio de DFD incluye ejemplos de diagrama de flujo para que te
familiarices con su interfaz.
Algoritmo
Lógica
Es un conjunto preescrito de instrucciones o reglas bien definidas, ordenadas y finitas que permite realizar una actividad mediante pasos sucesivos que no generen dudas a quien deba realizar
dicha actividad. Conjunto ordenado y finito de
operaciones que permite hallar la solución de
un problema.
Ciencia que expone las leyes, modos y formas
del conocimiento científico. La que opera utilizando un lenguaje simbólico artificial y haciendo abstracción de los contenidos.
Instrucción
Conjunto de datos insertados en una secuencia
estructurada o específica que el procesador interpreta y ejecuta.
Iteración
Acción y efecto de repetir.
Lenguaje
Es un idioma artificial diseñado para expresar
procesos que pueden ser llevadas a cabo por máquinas como los computadores. Pueden usarse
para crear programas que controlen el comportamiento físico y lógico de una máquina, para
expresar algoritmos con precisión, o como modo
de comunicación humana.
58
Sena Producción en multimedia
Fase Análisis
Fase Análisis
Plataforma
Es un sistema que sirve como base para hacer
funcionar determinados módulos de hardware o
de software con los que es compatible.
Pseucodigo
Es una descripción de un algoritmo informático
de programación de alto nivel compacto e informal que utiliza las convenciones estructurales de
un lenguaje de programación verdadero, pero que
está diseñado para la lectura humana en lugar de
la lectura en máquina, y con independencia de
cualquier otro lenguaje de programación.
Problema
Planteamiento de una situación cuya respuesta
desconocida debe obtenerse a través de métodos
científicos. Conjunto de hechos o circunstancias
que dificultan la consecución de algún fin.
Sena Producción en multimedia
59
en te s
fe re nc ia s y Fu
Bi bl io gr af ía , Re
Bibliografía, Referencias y Fuentes
ito ria l
Cr éd ito s de ed
Créditos de editorial
De Sanchez, M. (2004). Aprende a Pensar 5 – Solución de Problemas. México DF: Editorial Trillas.
SENA, (2011, 20 de Diciembre). Metodología de la Programación de Sistemas Informáticos. Bogotá DC: Servicio Nacional de Aprendizaje. Recuperado el 18 de abril de 2010 de
http://www.senavirtual.edu.co.
Cairó, O. (2008). Metodología de la Programación, algoritmos, diagramas de flujo y programas
(3a. Ed.). Buenos Aires: Alfa Omega Grupo Editor.
Descargar LPP [Lenguaje de Programación para principiantes]. Recuperado el 20 de noviembre
de 2011 de
http://www.gratisprogramas.org/descargar/lpp-lenguaje-de-programacion-para-principiantes-rs/
Revisión, Preparación y
Compilación.
Freddy Oswaldo Ovalles Pabón
Instructor Multimedia SENA Regional Norte de
Santander Centro CIES.
fovalles@misena.edu.co
Diseño editorial
Alejandro Orozco Escobar
Iliana Eneth Molina Cuartas
Profesional grado 10
ilmocu@sena.pedu.co
Revisión Temática
Dorian sully munera rua
Diseñador visual Profesional
designifrit@gmail.com
Revisión Metodológica y
Corrección de Estilo
Diagramación
Adriana Marcela Bedoya V
Alejandro Orozco Escobar
Diseñador visual Profesional
Colaboración
Sergio Areiza
Diseñador gráfico
sergioareiza@hotmail.com
Sena Producción en multimedia
Líder de produccíon
dsmunera@misena.edu.co
DFD Descargar (2008, 23 de octubre). Recuperado el 20 de noviembre de 2011 de
http://dfd.softonic.com/
60
Equipo de Exper tos temáticos y de
Diseño para Producción de
Multimedia SENA
Fase Análisis
Fase Análisis
abedoya@misena.edu.co
Ilustración
Alejandro Orozco Escobar
Diseñador visual Profesional
Mario Andrés Sepulveda Mazo
Diseñador visual Profesional
m_sepulveda@misena.edu.co
Sena Producción en multimedia
61
Co nt ra ta pa
lisis
Fase de aná
62
Sena Producción en multimedia
Fase Análisis
Descargar